• <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>

            旭++

            張旭的C++學習筆記
            posts - 5, comments - 8, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            linux fork函數學習

            Posted on 2007-12-02 15:20 張旭 閱讀(11610) 評論(7)  編輯 收藏 引用
            在編寫socket ftp之前,我對fork函數進行了學習。
            先看這段范例代碼:
            #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 %dn",getpid()); 


                    
            else 


                            printf(
            "i am the parent process, my process id is %dn",getpid()); 



            }
             

            這段代碼寫了一個使用fork函數創建子進程,父子進程同時運行而產生交錯的,不一樣的運行結果。
            運行結果如下:
            [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 
                  fork在英文中是叉子,分叉的意思,在函數fork中,取后面的意思。很形象的表示程序從這里分叉,fork函數創建了子進程,子進程和父進程同時(其實是cpu分時處理)開始運行分叉之后的程序。
                  我把程序改寫了一下: 

             

            #include <unistd.h>
            #include 
            <sys/types.h>
            main()
            {
                    pid_t pid;
                    printf(
            "\n[%d]not fork pid=%d\n",getpid(),pid);
                    pid
            =fork();
                    printf(
            "\n[%d]forked pid=%d\n",getpid(),pid);
                    
            if(pid<0)
                    
            {
                            printf(
            "error in fork!\n");
                            getchar();
                            exit(
            1);
                    }

                    
            else if(pid==0)
                            printf(
            "\n[%d]in child process,p_id=%d\n",getpid(),getpid());
                    
            else
                    
            {
                            printf(
            "\n[%d]in parent process,my pid=%d\n",getpid(),pid);
                            printf(
            "\n[%d]in parent process,my getpid=%d\n",getpid(),getpid());

                    }

            }


            程序運行結果如下:
            [hardy@localhost fork]$ ./fork

            [3819]not fork

            [3820]forked pid=0

            [3820]in child process,p_id=3820

            [3819]forked pid=3820

            [3819]in parent process,my pid=3820

            [3819]in parent process,my getpid=3819

            可以清楚的看到 not fork只打印了一次,其中[3819]是父進程的進程號,創建fork以后,fork函數返回給父進程的值pid是子進程的進程號[3820],而在子進程中,pid值為零。也就是說子進程中,pid被置零。

            引用網上一位網友的解釋“其實就相當于鏈表,進程形成了鏈表,父進程pid(p 意味point)指向子進程的進程id, 因為子進程沒有子進程,所以其pid為0. 

            下面有一個很有意思的程序:
            #include <sys/types.h>
            #include 
            <unistd.h>

            int main()
            {
                    
            int i;
                    
            for( i= 0; i< 3; i++)
                    
            {
                            
            int pid= fork();
                            
            if(pid== 0)
                            
            {
                                    printf(
            "son\n");
                            }

                            
            else
                            
            {
                                    printf(
            "father\n");
                            }

                    }

                    
            return 0;
            }


            大家想想看最后將出現幾個son 幾個father呢?

            。
            。
            。

            。
            。

            對一下答案吧:
            [hardy@localhost fork]$ ./fork
            father
            son
            son
            son
            father
            father
            son
            father
            son
            son
            father
            father
            son
            father

            總共7個son7個father。你答對了么?

            這道題需要在紙上畫畫才好理解
            for            i=0         1           2
                           father     father     father
                                                       son
                                          son       father
                                                        son
                           son       father        father
                                                         son
                                          son         father
                                                         son
            其中每一行分別代表一個進程的運行打印結果。
            當產生子進程的時刻,子進程打印son,當子進程調用fork的生成子子進程,他就提升為father。
            總結來說,father永遠打印father,son在fork之前是son,fork之后就為father,同時生成新的son。
            這個比喻就像真正的父子,孩子長大了生了小孩,孩子就成了父親。而父親永遠是父親。

            Feedback

            # re: linux fork函數學習  回復  更多評論   

            2008-08-06 12:55 by zcc
            xhu,2舍的張旭?不會真的是你吧?呵呵,我搜索fork()的時候搜到了這里,如果真你是你該知道我是哪個了吧,呵呵,我是zcc

            # re: linux fork函數學習  回復  更多評論   

            2008-08-06 13:00 by 張旭
            @zcc
            抱歉,我想不起來你是誰??赡苷J錯了吧。

            # re: linux fork函數學習  回復  更多評論   

            2009-02-21 18:39 by
            很強大。。。

            # re: linux fork函數學習  回復  更多評論   

            2012-01-06 17:21 by er
            gcc怎么寫

            # re: linux fork函數學習[未登錄]  回復  更多評論   

            2012-04-10 20:56 by noname
            good!

            # re: linux fork函數學習[未登錄]  回復  更多評論   

            2012-04-10 20:58 by noname
            請問最后一個程序,是不是father和son的輸出沒有規律,第一組是father和son的組合,第二組是兩個father和兩個son的組合,最后一組是四個father和四個son的組合就是了嗎?

            # re: linux fork函數學習  回復  更多評論   

            2012-08-23 18:55 by 過客
            你知道fork后系統是怎么分清那個該子進程運行哪些是父進程運行嗎?
            久久久久免费看成人影片| 久久久国产乱子伦精品作者| 99久久人妻无码精品系列| 亚洲欧洲久久av| 久久伊人色| 久久人妻少妇嫩草AV蜜桃| 久久精品一区二区三区中文字幕| 精品久久香蕉国产线看观看亚洲| 亚洲国产精品无码久久久秋霞2 | 免费精品久久久久久中文字幕| 久久精品aⅴ无码中文字字幕不卡| 亚洲国产精品18久久久久久| 久久国产综合精品五月天| 18岁日韩内射颜射午夜久久成人| 久久综合久久综合久久| 久久无码人妻一区二区三区| 丁香色欲久久久久久综合网| 亚洲AV无码1区2区久久| 久久99国产综合精品女同| 久久精品国产亚洲av麻豆色欲| 国产综合成人久久大片91| 久久一本综合| 亚洲精品综合久久| 亚洲午夜久久久久久久久久| 久久亚洲精品成人无码网站| 久久久久亚洲Av无码专| 国产精品亚洲美女久久久| 久久亚洲中文字幕精品一区四| 亚洲αv久久久噜噜噜噜噜| 久久亚洲精品人成综合网| 久久综合九色综合精品| 久久精品女人天堂AV麻| 超级97碰碰碰碰久久久久最新| 99久久免费国产精精品| a级毛片无码兔费真人久久| 久久久久久国产a免费观看不卡| 日韩精品久久无码中文字幕| 国内精品久久九九国产精品| 亚洲欧美另类日本久久国产真实乱对白| 7777久久久国产精品消防器材| 四虎国产精品免费久久久 |