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

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 326856
            • 排名 - 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
            久久精品国产乱子伦| 国产精品伦理久久久久久| 久久久这里有精品| 欧洲人妻丰满av无码久久不卡| 久久久久久狠狠丁香| 亚洲国产视频久久| 亚洲国产精久久久久久久| 污污内射久久一区二区欧美日韩| 久久久久久亚洲AV无码专区| 91精品国产91久久| 精品无码久久久久久尤物| 国产精品久久毛片完整版| 久久久久久亚洲精品无码| 久久国产精品99国产精| 久久综合五月丁香久久激情| 久久精品毛片免费观看| 久久人人爽人人爽人人爽| 伊人久久大香线蕉精品| 日韩人妻无码精品久久免费一| 久久综合伊人77777麻豆| 久久精品成人免费网站| 一本一本久久A久久综合精品 | 91精品国产高清久久久久久国产嫩草 | 久久久久亚洲AV成人网人人网站| 女人香蕉久久**毛片精品| 久久精品中文闷骚内射| 热久久最新网站获取| 国产精品日韩深夜福利久久| www.久久热| 国产99久久精品一区二区| 浪潮AV色综合久久天堂| av色综合久久天堂av色综合在| 中文字幕久久精品 | 久久精品国产亚洲AV香蕉| 人人狠狠综合88综合久久| 亚洲а∨天堂久久精品9966| 久久亚洲国产精品123区| 久久无码人妻精品一区二区三区| 国产精品日韩欧美久久综合| 久久久国产精华液| 香蕉久久夜色精品国产尤物|