对while((pid = waitpid(-1, &stat, WNOHANG)) > 0)不懂的地方,现在懂了

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,所以要用循环去处理.把僵尸进程回收完

上一篇:html5 拖放到购物车


下一篇:HashSet的实现原理