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 ", i); while (waitpid(0, NULL, WNOHANG) > 0) { static int j = 0; j++; printf("j:%d ", j); } }