wait如何處理多進程(多個子進程)

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
/* linux 系統調用 wait()
 * 當用fork()創建子進程,子進程在退出後父進程沒有調用wait
 * 就會產生殭屍進程.
 *
 * 下面是用fork循環創建多個子進程,在父進程裏調用一次wait
 * 只能回收一個子進程.
 *
 * 下面展示如何用wait()回收多個子進程.
 *
 * */
int main(void)
{
    int procnum = 0, loopnum = 0;
    int i = 0, j = 0;
    pid_t fpid;

    printf("procnum = ");
    scanf("%d", &procnum);

    printf("loopnum = ");
    scanf("%d", &loopnum);

    for (i = 0; i < procnum; i++) { 
        fpid = fork();
        //printf("child pid: %d\n", getpid());
        if (fpid == 0){
            for (j = 0; j < loopnum; j++) {
                printf("loop %d\n", j); 
            }
            exit(0);
        }
    }

    wait(NULL);  //調用一次,只能回收一個子進程
    sleep(1000);
    printf("parrent pid: %d\n", getpid());

    return 0;
}

運行截圖
從截圖中可以看到,產生了五個進程,調用一次wait只能回收一個子進程,還有四個殭屍進程,如何回收所有子進程呢,程序改進如下:

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
/* linux 系統調用 wait()
 * 當用fork()創建子進程,子進程在退出後父進程沒有調用wait
 * 就會產生殭屍進程.
 *
 * 下面是用fork循環創建多個子進程,在父進程裏調用一次wait
 * 只能回收一個子進程.
 *
 * 下面展示如何用wait()回收多個子進程.
 *
 * */
int main(void)
{
    int procnum = 0, loopnum = 0;
    int i = 0, j = 0;
    int ret = 0;
    pid_t fpid;

    printf("procnum = ");
    scanf("%d", &procnum);

    printf("loopnum = ");
    scanf("%d", &loopnum);

    for (i = 0; i < procnum; i++) { 
        fpid = fork();
        //printf("child pid: %d\n", getpid());
        if (fpid == 0){
            for (j = 0; j < loopnum; j++) {
                printf("loop %d\n", j); 
            }
            exit(0);
        }
    }

    // 檢測到所有子進程都退出,父進程才退出
    while (1) {
        ret = wait(NULL);
        if (ret == -1) {
            if (errno == EINTR) {    // 返回值爲-1的時候有兩種情況,一種是沒有子進程了,還有一種是被中斷了
                continue;
            }

            break;
        }
    }
    printf("parrent pid: %d\n", getpid());

    return 0;
}

這裏寫圖片描述
可以看到,已經沒有殭屍進程了..

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章