#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;
}
可以看到,已經沒有殭屍進程了..