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

            為生存而奔跑

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks

            留言簿(5)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 326887
            • 排名 - 74

            最新評論

            閱讀排行榜

            評論排行榜

            一般的,父進程在生成子進程之后會有兩種情況,一種是父進程繼續去做別的事情,另一種是父進程啥都不做,一直在wait子進程退出.SIGCHLD信號就是為這第一種情況準備的,它讓父進程去做別的事情,而只要父進程注冊了處理該信號的函數,在子進程退出時就會調用該函數,在該函數中又可以調用wait得到終止的子進程的狀態。處理信號的函數執行完后,再繼續做父進程的事情.

            也就是說,如果父進程在fork之后調用wait,就會阻塞,直到有一個子進程退出。
            如果父進程在fork之前先signal(SIGCLD, sig_cld),即注冊了SIGCLD的信號處理函數。然后做自己的事情。當子進程退出時,會給父進程發送一個SIGCLD信號。然后sig_cld函數就會執行。可以在sig_cld函數中調用wait獲得子進程退出時的狀態,并且此時wait不會阻塞。 當sig_cld函數執行完后,父進程又繼續做自己的事情。

            #include<sys/wait.h>
            #include
            <stdio.h>
            #include
            <stdlib.h>
            #include
            <unistd.h>

            #include
            <sys/wait.h>

            static void sig_cld(int);

            int main()
            {
                pid_t pid;
                
            int status;

                
            if(signal(SIGCLD,sig_cld) ==  SIG_ERR)
                {
                    printf(
            "signal error\n");
                    exit(
            -1);
                }
                
            if((pid = fork()) < 0)
                {
                    printf(
            "fork error\n");
                    exit(
            -1);
                }
                
            else if(pid == 0)
                {
                    
            //child
                    printf("%d fork a new child %d\n",getppid(),getpid());
                    sleep(
            1);
                    _exit(
            19);
                }
                
            else
                {
                    
            //parent
                    int i,j;
                    
            for(i=0;i<100;i++)
                    {
                        
            for(j=0;j<10000000;j++);
                        printf(
            "%d\n",i);
                    }
                    
                }

            }

            static void sig_cld(int signo)
            {
                pid_t pid;
                
            int status;

                printf(
            "SIGCLD received\n");
                
                
            if((pid = wait(&status)) <0)
                {
                    printf(
            "wait error\n");
                }
                printf(
            "pid = %d\n",pid);
            }

            posted on 2011-03-17 16:03 baby-fly 閱讀(3101) 評論(0)  編輯 收藏 引用 所屬分類: Ubuntu&Linux
            亚洲欧美日韩久久精品| 久久棈精品久久久久久噜噜| 999久久久无码国产精品| 国产精品一区二区久久不卡| 91久久精品国产免费直播| 亚洲а∨天堂久久精品| 亚洲精品乱码久久久久久自慰| 精品永久久福利一区二区| 亚洲国产精品成人久久| 午夜天堂av天堂久久久| 国产成人久久精品一区二区三区| 精品国产一区二区三区久久久狼| 久久夜色精品国产噜噜噜亚洲AV| 久久精品国产只有精品66| 久久久噜噜噜www成人网| 嫩草伊人久久精品少妇AV| 国产国产成人精品久久| 婷婷综合久久中文字幕| 久久久久国色AV免费观看| 亚洲精品无码久久久| 久久无码人妻一区二区三区午夜 | 一本大道加勒比久久综合| 国产精品久久久天天影视| 精品久久久久国产免费 | 亚洲国产精品无码久久久蜜芽| 久久精品国产亚洲AV香蕉| 国内精品久久久久久久涩爱| 久久久久亚洲爆乳少妇无| 日韩欧美亚洲综合久久影院d3| 久久99精品国产麻豆宅宅| 国产精品久久久久久| 久久综合久久伊人| 欧美噜噜久久久XXX| 久久久久久国产精品美女| 色诱久久久久综合网ywww| 久久国产乱子伦精品免费午夜| 亚洲中文精品久久久久久不卡| 四虎国产精品成人免费久久| 一本一本久久a久久精品综合麻豆| 久久精品中文字幕无码绿巨人| 久久成人18免费网站|