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

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 328427
            • 排名 - 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 閱讀(3110) 評論(0)  編輯 收藏 引用 所屬分類: Ubuntu&Linux
            久久婷婷国产剧情内射白浆 | 99久久综合国产精品二区| 久久频这里精品99香蕉久| 久久无码AV一区二区三区| 99久久国产综合精品女同图片| 日韩人妻无码一区二区三区久久| 2022年国产精品久久久久 | 久久夜色精品国产网站| 色噜噜狠狠先锋影音久久| 热99RE久久精品这里都是精品免费 | 久久国产精品-久久精品| 久久中文字幕人妻丝袜| 精品久久久久久久无码| 久久久久久午夜精品| 99re这里只有精品热久久| 久久久久久久国产免费看| 日日躁夜夜躁狠狠久久AV| 久久av高潮av无码av喷吹| 久久久亚洲欧洲日产国码aⅴ| 精品久久久久久无码国产| 波多野结衣AV无码久久一区| 国产精品成人99久久久久91gav| 国产成人无码精品久久久性色| 国产亚州精品女人久久久久久| 性做久久久久久久| 青青草原精品99久久精品66| 日韩精品无码久久一区二区三| 国产精品丝袜久久久久久不卡| 亚洲精品乱码久久久久久蜜桃不卡 | 亚洲国产综合久久天堂| 无码任你躁久久久久久久| 麻豆精品久久久一区二区| 精品久久久无码人妻中文字幕豆芽 | 久久久久久久97| 久久久久亚洲AV片无码下载蜜桃| 伊人久久国产免费观看视频| 久久综合色之久久综合| 久久婷婷午色综合夜啪| 久久只有这里有精品4| 2019久久久高清456| 一本一道久久综合狠狠老|