为什么 while((pid = waitpid(-1, &stat, WNOHANG)) > 0)能处理所有子进程

在unp中有一节代码是这样的:

void sig_chld(int signo)
{
       pid_t   pid;
       int     stat;
       
       while((pid = waitpid(-1, &stat, WNOHANG)) > 0){
               printf("child %d terminated\n", pid);
       }
        return;
}

见unp第110页。

是什么?

它是一个SIGCHLD信号处理程序。当父进程的一个子进程结束时,会给父进程发送一个SIGCHLD信号。

核心在哪儿?

当父进程的5个子进程同时向父进程发送SIGCHILD时会发生什么?

父进程只会调用一次信号处理程序,并丢弃其余四个信号。虽然只接受了一个SIGCHLD信号,但是

while((pid = waitpid(-1, &stat, WNOHANG)) > 0)

这条语句会处理所有的僵尸子进程。这就意味着,即使丢失了一部分SIGCHLD信号,父进程也能够回收所有的子进程。

为什么?

事实上,waitpid与SIGCHLD信号的关联并不大。waitpid的函数构造是,回收第一个僵尸子进程。而加上while之后就能够回收所有在while运行期间内结束的子进程。与SIGCHLD关系不大。

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值