while((pid = waitpid(-1, &stat, WNOHANG)) > 0)
需要写到信号处理函数中,假如有10个子进程
只要父进程能够收到最后一个信号,就能把前面丢失的所产生的僵尸进程回收完.
而父进程是能够收到最后一个信号的,就算父进程在子进程结束到第5个的时候,开始进行信号函数的处理.
如果由于处理时间过长,导致剩下5个也在处理函数执行的过程中结束掉.这时,由于信号处理机制会导致剩下5个传递的信号会被阻塞,当然由于该信号不排队
所以未决集只会有一个信号(当阻塞集相应位至1时,如果有相应信号到达,未决集至1,表示有未决的信号).至此,子进程已经全部结束,当信号函数执行完毕后,内核开放阻塞信号集,那么.之前被阻塞掉的那个信号传递进来.
接下来再次回收剩下的僵尸进程.
下面将给出代码,显示,信号函数的执行次数与回收次数的计数.就能看出区别
void hander(int n) { static int i = 0; i++; printf(" i:%d\n", i); while (waitpid(0, NULL, WNOHANG) > 0) { static int j = 0; j++; printf("j:%d\n", j); } }
waitpid(-1, &stat, WNOHANG)回收子进程,回收成功一个,返回子进程的pid,
如果WNOHANG被指定,将不再阻塞回收,此时的返回规则是.如果有子进程,但没有结束(没有变成僵尸进程),waitpid返回0,如果有僵尸进程,回收一个僵尸进程,返回僵尸进程pid,所以要用循环去处理.把僵尸进程回收完
时间: 2024-09-29 21:04:11