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

            天之道

            享受編程的樂趣。
            posts - 118, comments - 7, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            wait 和waitpid詳解

            Posted on 2013-04-13 22:05 hoshelly 閱讀(1366) 評論(0)  編輯 收藏 引用 所屬分類: Linux
            wait的函數原型是:  
            #include<sys/types.h>
            #include <sys/wait.h>

            pid_t wait(int *status)     
                  進程一旦調用了wait,就立即阻塞自己,由wait自動分析是
            否當前進程的某個子進程已經退出,如果讓它找到了這樣一個
            已經變成僵尸的子進程, wait就會收集這個子進程的信息,并
            把它徹底銷毀后返回;如果沒有找到這樣一個子進程,wait就
            會一直阻塞在這里,直到有一個出現為止。    
                  參數status用來保存被收集進程退出時的一些狀態,它是
            一個指向int類型的指針。但如果我們對這個子進程是如何死掉
            的毫不在意,只想把這個僵尸進程消滅掉,(事實上絕大多數
            情況下,我們都會這樣想),我們就可以設定這個參數為
            NULL,就象下面這樣:     pid = wait(NULL);
            如果成功,wait會返回被收集的子進程的進程ID,如果調用進
            程沒有子進程,調用就會失敗,此時wait返回-1,同時errno被
            置為ECHILD。 
                  waitpid的函數原型是:   
            waitpid系統調用在Linux函數庫中的原型是:   
            #include <sys/types.h>#include <sys/wait.h>

            pid_t waitpid(pid_t pid,int *status,int options)
                  從本質上講,系統調用waitpid和wait的作用是完全相同
            的,但waitpid多出了兩個可由用戶控制的參數pid和options,
            從而為我們編程提供了另一種更靈活的方式。
            下面我們就來詳細介紹一下這兩個參數:     
            ● pid     從參數的名字pid和類型pid_t中就可以看出,
            這里需要的是一個進程ID。但當pid取不同的值時,在這里有不
            同的意義。     pid>0時,只等待進程ID等于pid的子進
            程,不管其它已經有多少子進程運行結束退出了,只要指定的
            子進程還沒有結束,waitpid就會一直等下去。     pid=-
            1時,等待任何一個子進程退出,沒有任何限制,此時waitpid
            和wait的作用一模一樣。     pid=0時,等待同一個進程
            組中的任何子進程,如果子進程已經加入了別的進程組,
            waitpid不會對它做任何理睬。     pid<-1時,等待一個
            指定進程組中的任何子進程,這個進程組的ID等于pid的絕對
            值。   
            ● options   options提供了一些額外的選項來控制waitpid,
            目前在Linux中只支持WNOHANG和WUNTRACED兩個選項,
            這是兩個常數,可以用"|"運算符把它們連接起來使用,比如:
              ret=waitpid(-1,NULL,WNOHANG | WUNTRACED);   
            如果我們不想使用它們,也可以把options設為0,如:   
            ret=waitpid(-1,NULL,0);     如果使用了WNOHANG參數
            調用waitpid,即使沒有子進程退出,它也會立即返回,不會像
            wait那樣永遠等下去。     而WUNTRACED參數,由于
            涉及到一些跟蹤調試方面的知識,加之極少用到,這里就不多
            費筆墨了,有興趣的讀者可以自行查閱相關材料。    看
            到這里,聰明的讀者可能已經看出端倪了--wait不就是經過包裝
            的waitpid嗎?沒錯,察看<內核源碼目錄>/include/unistd.h文
            件349-352行就會發現以下程序段:     static inline
            pid_t wait(int * wait_stat)   {    return waitpid(-
            1,wait_stat,0);   }      返回值和錯誤     
            waitpid的返回值比wait稍微復雜一些,一共有3種情況:  
            ● 當正常返回的時候,waitpid返回收集到的子進程的進程ID;
            ● 如果設置了選項WNOHANG,而調用中waitpid發現沒有已
            退出的子進程可收集,則返回0;      
            ● 如果調用中出錯,則返回-1,這時errno會被設置成相應的
            值以指示錯誤所在;當pid所指示的子進程不存在,或此進程存
            在,但不是調用進程的子進程,waitpid就會出錯返回,這時
            errno被設置為ECHILD 其它: 調用 wait&waitpid 來處理終止
            的子進程: pid_t wait(int * statloc); pid_t waitpid(pid_t pid,
            int *statloc, int options); 兩個函數都返回兩個值:函數的返回
            值和終止的子進程ID,而子進程終止的狀態則是通過statloc指
            針返回的。 wait&waitpid 的區別是顯而易見的,wait等待第一
            個終止的子進程,而waitpid則可以指定等待特定的子進程。這
            樣的區別可能會在下面這種情況時表現得更加明顯:當同時有
            5個客戶連上服務器,也就是說有五個子進程分別對應了5個客
            戶,此時,五個客戶幾乎在同時請求終止,這樣一來,幾乎同
            時,五個FIN發向服務器,同樣的,五個SIGCHLD信號到達服
            務器,然而,UNIX的信號往往是不會排隊的,顯然這樣一來,
            信號處理函數將只會執行一次,殘留剩余四個子進程作為僵尸
            進程駐留在內核空間。此時,正確的解決辦法是利用waitpid(-
            1, &stat, WNOHANG)防止留下僵尸進程。其中的pid為-1表
            明等待第一個終止的子進程,而WNOHANG選擇項通知內核在
            沒有已終止進程項時不要阻塞。
            wait&waitpid 區別 :
            waitpid提供了wait函數不能實現的3個功能: waitpid等待特定的
            子進程, 而wait則返回任一終止狀態的子進程; waitpid提供了一
            個wait的非阻塞版本; waitpid支持作業控制(以WUNTRACED選
            項). 用于檢查wait和waitpid兩個函數返回終止狀態的宏: 這兩個
            函數返回的子進程狀態都保存在statloc指針中, 用以下3個宏可
            以檢查該狀態: WIFEXITED(status): 若為正常終止, 則為真. 此
            時可執行 WEXITSTATUS(status): 取子進程傳送給exit或_exit
            參數的低8位. WIFSIGNALED(status): 若為異常終止, 則為真.
            此時可執行 WTERMSIG(status): 取使子進程終止的信號編號.
            WIFSTOPPED(status): 若為當前暫停子進程, 則為真. 此時可
            執行 WSTOPSIG(status): 取使子進程暫停的信號編號
            亚洲精品乱码久久久久66| 久久精品无码免费不卡| 久久精品亚洲AV久久久无码| 亚洲天堂久久久| 久久精品国产亚洲av水果派| 久久精品一区二区三区不卡| 久久久噜噜噜久久| 久久精品无码午夜福利理论片| 国产毛片久久久久久国产毛片| 久久婷婷午色综合夜啪| 久久精品国产一区| 久久久无码人妻精品无码| 久久精品国产99久久久香蕉| 无码人妻少妇久久中文字幕蜜桃 | 久久精品亚洲精品国产欧美| 久久青青草视频| 色综合久久中文综合网| 国产精品久久久久蜜芽| 亚洲狠狠综合久久| 久久久av波多野一区二区| 伊人久久亚洲综合影院| 91久久香蕉国产熟女线看| 2022年国产精品久久久久| 伊人久久综合成人网| 思思久久99热只有频精品66| 久久精品无码专区免费| 99热热久久这里只有精品68| 久久久久高潮毛片免费全部播放| 一级a性色生活片久久无| 久久久久亚洲精品天堂久久久久久 | 人人狠狠综合久久亚洲88| 国产精品久久久久国产A级| 久久精品国产精品亚洲精品 | 免费精品99久久国产综合精品| 久久久久波多野结衣高潮| 一97日本道伊人久久综合影院| 国产激情久久久久影院老熟女免费| 久久国产高潮流白浆免费观看| 久久国产精品99精品国产| 久久精品男人影院| 精品国产乱码久久久久久浪潮|