• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            syhd142  
            日歷
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567
            統計
            • 隨筆 - 23
            • 文章 - 122
            • 評論 - 31
            • 引用 - 0

            導航

            常用鏈接

            留言簿(2)

            隨筆檔案(23)

            文章分類(270)

            文章檔案(122)

            我的豆瓣

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             
            操作系統的作業要求編程實現一個命令解釋器的接口,要求用多進程實現,fork的方法還不會,網上google了一下,發現在chinaunix論壇里面有很詳細的解釋
            以下內容轉至:http:
            //www.chinaunix.net/jh/23/311067.html
            問題如下:
            #include 
            <unistd.h>;
            #include 
            <sys/types.h>;
            main ()
            {
                    pid_t pid;
                    pid
            =fork();
                    
            if (pid < 0)
                            printf(
            "error in fork!");
                    
            else if (pid == 0)
                            printf(
            "i am the child process, my process id is %d\n",getpid());
                    
            else
                            printf(
            "i am the parent process, my process id is %d\n",getpid());
            }

            結果是 
            [root@localhost c]# .
            /a.out 
            i am the child process, my process id 
            is 4286 
            i am the parent process, my process id 
            is 4285 


            我就想不到為什么兩行都打印出來了,在我想來,不管pid是多少,都應該只有一行才對

            網友解答:
            要搞清楚fork的執行過程,就必須先講清楚操作系統中的“進程(process)”概念。一個進程,主要包含三個元素: 

            o. 一個可以執行的程序; 
            o. 和該進程相關聯的全部數據(包括變量,內存空間,緩沖區等等); 
            o. 程序的執行上下文(execution context)。 

            不妨簡單理解為,一個進程表示的,就是一個可執行程序的一次執行過程中的一個狀態。操作系統對進程的管理,典型的情況,是通過進程表完成的。進程表中的每一個表項,記錄的是當前操作系統中一個進程的情況。對于單 CPU的情況而言,每一特定時刻只有一個進程占用 CPU,但是系統中可能同時存在多個活動的(等待執行或繼續執行的)進程。 

            一個稱為“程序計數器(program counter, pc)”的寄存器,指出當前占用 CPU的進程要執行的下一條指令的位置。 

            當分給某個進程的 CPU時間已經用完,操作系統將該進程相關的寄存器的值,保存到該進程在進程表中對應的表項里面;把將要接替這個進程占用 CPU的那個進程的上下文,從進程表中讀出,并更新相應的寄存器(這個過程稱為“上下文交換(process context 
            switch)”,實際的上下文交換需要涉及到更多的數據,那和fork無關,不再多說,主要要記住程序寄存器pc指出程序當前已經執行到哪里,是進程上下文的重要內容,換出 CPU的進程要保存這個寄存器的值,換入CPU的進程,也要根據進程表中保存的本進程執行上下文信息,更新這個寄存器)。 

            好了,有這些概念打底,可以說fork了。當你的程序執行到下面的語句: 
            pid
            =fork();  
            操作系統創建一個新的進程(子進程),并且在進程表中相應為它建立一個新的表項。新進程和原有進程的可執行程序是同一個程序;上下文和數據,絕大部分就是原進程(父進程)的拷貝,但它們是兩個相互獨立的進程!此時程序寄存器pc,在父、子進程的上下文中都聲稱,這個進程目前執行到fork調用即將返回(此時子進程不占有CPU,子進程的pc不是真正保存在寄存器中,而是作為進程上下文保存在進程表中的對應表項內)。問題是怎么返回,在父子進程中就分道揚鑣。 

            父進程繼續執行,操作系統對fork的實現,使這個調用在父進程中返回剛剛創建的子進程的pid(一個正整數),所以下面的if語句中pid
            <0, pid==0的兩個分支都不會執行。所以輸出i am the parent process 

            子進程在之后的某個時候得到調度,它的上下文被換入,占據 CPU,操作系統對fork的實現,使得子進程中fork調用返回0。所以在這個進程(注意這不是父進程了哦,雖然是同一個程序,但是這是同一個程序的另外一次執行,在操作系統中這次執行是由另外一個進程表示的,從執行的角度說和父進程相互獨立)中pid
            =0。這個進程繼續執行的過程中,if語句中pid<0不滿足,但是pid==0是true。所以輸出i am the child process 

            我想你比較困惑的就是,為什么看上去程序中互斥的兩個分支都被執行了。在一個程序的一次執行中,這當然是不可能的;但是你看到的兩行輸出是來自兩個進程,這兩個進程來自同一個程序的兩次執行。 

            我的天,不知道說明白了沒……

            問題接踵而來,又有人問:
            我做如下修改 

            #include 
            <unistd.h>;  
            #include 
            <sys/types.h>;  
            main ()  
            {  
                    pid_t pid;  
                    printf(
            "fork!");    // printf("fork!\n"); 
                    pid=fork();  
                    
            if (pid < 0)  
                            printf(
            "error in fork!");  
                    
            else if (pid == 0)  
                            printf(
            "i am the child process, my process id is %d\n",getpid());  
                    
            else  
                            printf(
            "i am the parent process, my process id is %d\n",getpid());  
            }  

            結果是  
            [root@localhost c]# .
            /a.out  
            fork
            !i am the child process, my process id is 4286  
            fork
            !i am the parent process, my process id is 4285 

            但我改成printf(
            "fork!\n");后,結果是 
            [root@localhost c]# .
            /a.out 
            fork
            !  
            i am the child process, my process id 
            is 4286  
            i am the parent process, my process id 
            is 4285 

            為什么只有一個fork
            !打印出來了?上一個為什么有2個?

            又有強人回復:
            我也來一下: 
            wujiajia 的理解有些錯誤, 
            printf(
            "AAAAAAAA");//print 一次;   這里會print 2次 
            如果你將 printf("AAAAAA") 換成 printf("AAAAAA\n")   那么就是只打印一次了. 
            主要的區別是因為有了一個 \n  回車符號 
            這就跟Printf的緩沖機制有關了,printf某些內容時,操作系統僅僅是把該內容放到了stdout的緩沖隊列里了,并沒有實際的寫到屏幕上 
            但是,只要看到有 \n 則會立即刷新stdout,因此就馬上能夠打印了. 
            運行了printf(
            "AAAAAA") 后, AAAAAA 僅僅被放到了緩沖里,再運行到fork時,緩沖里面的 AAAAAA 被子進程繼承了 
            因此在子進程度stdout緩沖里面就也有了 AAAAAA. 
            所以,你最終看到的會是 AAAAAA 被printf了2次
            !!!! 
            而運行 printf(
            "AAAAAA\n")后, AAAAAA 被立即打印到了屏幕上,之后fork到的子進程里的stdout緩沖里不會有 AAAAAA 內容 
            因此你看到的結果會是 AAAAAA 被printf了1次
            !!!!

            posted on 2010-12-10 12:42 Fucker 閱讀(336) 評論(0)  編輯 收藏 引用
             
            Copyright © Fucker Powered by: 博客園 模板提供:滬江博客
            精品国产一区二区三区久久久狼| 久久不见久久见免费视频7| 久久乐国产精品亚洲综合| 亚洲国产天堂久久综合| 久久综合九色综合网站| 国产精品久久久久一区二区三区| 色天使久久综合网天天| 久久亚洲精品成人av无码网站| 热99re久久国超精品首页| 一日本道伊人久久综合影| 欧美熟妇另类久久久久久不卡| 情人伊人久久综合亚洲| 久久夜色精品国产欧美乱| 欧美激情精品久久久久久| 久久亚洲国产欧洲精品一| 无码国产69精品久久久久网站| 嫩草影院久久国产精品| 久久精品人人做人人爽电影| 久久人妻少妇嫩草AV蜜桃| 国产精品久久久久aaaa| 一本一道久久a久久精品综合| 欧美精品一本久久男人的天堂| 亚洲精品乱码久久久久久久久久久久| 99久久99久久精品国产片果冻| 久久精品欧美日韩精品| 久久精品国产99久久久古代 | 伊人伊成久久人综合网777| 国产精品99精品久久免费| 久久婷婷五月综合国产尤物app| 久久精品国产WWW456C0M| 人人狠狠综合久久亚洲88| 国产精品久久久久影视不卡| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 久久久久九国产精品| 精品久久久久久久久久久久久久久 | 中文字幕精品久久| 欧美一级久久久久久久大片| 精品多毛少妇人妻AV免费久久| 国产精品内射久久久久欢欢| 青青青国产精品国产精品久久久久| 久久久久久无码Av成人影院|