殭屍程序和孤兒程序

2021-07-31 09:32:05 字數 1307 閱讀 9670

孤兒程序:乙個父程序退出,而他的乙個或多個子程序還在執行,那麼那些子程序將會成為孤兒程序。孤兒程序將被init程序(程序號為1)所收養,並由init程序對他們完成狀態收集工作。

殭屍程序:乙個子程序在其父程序還沒有呼叫 wait() 或 waitpid() 的情況下退出。這個子程序就是殭屍程序。

還有一種情況就是父程序不斷地建立子程序

子程序退出時向父程序傳送sigchild訊號,父程序處理sigchild訊號。在訊號處理函式中呼叫wait進行處理殭屍程序。 就是讓子程序成為孤兒程序,從而它的父程序變為init程序,通過init程序可以處理殭屍程序。

任何乙個子程序(init除外)在exit()之後,並非馬上就消失掉,而是留下乙個稱為殭屍程序(zombie)的資料結構,等待父程序處理。這是每個子程序在結束時都要經過的階段。如果子程序在exit()之後,父程序沒有來得及處理,這時用ps命令就能看到子程序的狀態是「z」。如果父程序能及時處理,可能用ps命令就來不及看到子程序的殭屍狀態,但這並不等於子程序不經過殭屍狀態。 如果父程序在子程序結束之前退出,則子程序將由init接管。init將會以父程序的身份對子程序進行處理。

這樣來看,孤兒程序並不會有什麼危害,真正會對系統構成威脅的是僵死程序。例如有這樣乙個父程序:它定期的產生乙個子程序,這個子程序做完它該做的事情之後就退出了,因此這個子程序的生命週期很短,但是,父程序只管生成新的子程序,至於子程序退出之後的事情,則一概不聞不問,這樣,系統執行上一段時間之後,系統中就會存在很多的僵死程序,倘若用ps命令檢視的話,就會看到很多狀態為z的程序。 嚴格地來說,僵死程序並不是問題的根源,罪魁禍首是產生出大量僵死程序的那個父程序。因此,當我們需要消滅系統中大量的僵死程序時, 就要把產生大量僵死程序的那個殺掉(也就是通過kill傳送sigterm或者sigkill訊號)。槍斃了元凶程序之後,它產生的僵死程序就變成了孤兒程序,這些孤兒程序會被init程序接管,init程序會wait()這些孤兒程序,釋放它們占用的系統程序表中的資源 。

孤兒程序是子程序還在執行,而父程序已經退出,子程序被init程序收養。殭屍程序是父程序還在執行但是子程序已經退出了,但是父程序卻沒有使用wait來清理子程序的程序資訊,導致子程序雖然執行實體已經消失,但是仍然在核心的程序表中佔據一條記錄,這樣長期下去對於系統資源是乙個浪費。殭屍程序將會導致資源浪費,而孤兒程序則不會。

殭屍程序和孤兒程序

殭屍程序 乙個子程序在其父程序還沒有呼叫wait 或waitpid 的情況下退出。這個子程序就是殭屍程序。孤兒程序 乙個父程序退出,而它的乙個或多個子程序還在執行,那麼那些子程序將成為孤兒程序。孤兒程序將被init程序 程序號為1 所收養,並由init程序對它們完成狀態收集工作。殭屍程序將會導致資源...

殭屍程序和孤兒程序

什麼是殭屍程序?乙個子程序在其父程序沒有呼叫wait 或waitpid 的情況下退出。這個子程序就是殭屍程序。如果其父程序還存在而一直不呼叫wait,則該殭屍程序將無法 等到父程序結束後,會被init 驗證 include include includeint main 3秒後查詢其程序資訊 通過上...

殭屍程序和孤兒程序

殭屍程序和孤兒程序 在unix系統程式設計中,常常會碰到兩個概念 僵死程序和孤兒程序 僵死程序 在unix程序模型中,程序是按照父程序產生子程序,子程序產生子子程序這樣的方式建立出完成各項相互協作功能的程序的。當乙個程序完成它的工作終止之後,它的父程序需要呼叫wait 或者waitpid 系統呼叫取...