如何防止殭屍進程的產生之fork兩次

來源:互聯網
上載者:User

標籤:get   問題   for   type   io   一個   

#include<stdio.h>
#include<sys/types.h>
#include<sys/wait.h>
#include<unistd.h>
#include<signal.h>


int main( void )
{
    pid_t pid;


    if( (pid=fork()) < 0 )
    {
        fprintf(stderr, "main 1 fork err!\n");
        return 0;
    }
    else if( pid == 0 )
    {
        if( (pid=fork()) < 0 )
        {
            fprintf(stderr, "第二次fork err!\n");
            exit( -1 );
        }
        else if( pid > 0 )

        {

            fprintf( stderr, "子進程退出[%d]\n", getpid() );
            exit( 0 );
        }
        fprintf( stderr, "孫子進程[%d]\n", getpid() );
        while( 1 )
        {
        }
        exit( 0 );
    }


    /* wait第一個子進程退出 */
    waitpid( pid, NULL, 0 );
    fprintf( stderr, "父進程[%d]\n", getpid() );
    while( 1 )
    {
    }
    exit(0);
}

第一次fork後:父進程、子進程

第二次fork後:子進程、孫子進程


第一次fork後父進程wait子進程,

第二次fork後子進程立即退出,使得孫子進程成為孤兒進程繼續運行,同時也使得父進程wait完成結束進程掛起狀態繼續運行處理。

這樣可以避免殭屍進程的產生,同時父進程和孫子進程可以同時運行處理業務,避免了資源等待的問題。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.