- 论坛徽章:
- 0
|
其实我最近也在看这本书,心里话,觉得这本书的逻辑结构不是很好,尽管知识很详细,但是过于凌乱,不适合系统学习,当作补充还可以。楼主所提的文档我当时也搞不懂,后来去网上查了下,其实应该是这样的 :
void sig_chld(int signo)
{
pid_t pid;
int stat;
pid=wait(&stat);
printf("child termminated\n");
return;
}
复制代码
当使用下面这个信号处理函数,却不会有僵尸进程
void sig_chld(int signo)
{
pid_t pid;
int stat;
while((pid=waitpid(-1,&stat,WNOHANG))>0)
printf("child %d termminated\n",pid);
return;
}
最主要的是wait函数和waipid的区别,wait函数会一直阻塞知道有一个子进程死掉,但是waitpid确实在没有子进程死掉的时候有返回,一旦有子进程死掉就获取子进程的id。那样整个函数不会是在阻塞状态。
这是我个人的理解,当然书上的表达是waitpid会一直循环等待死掉的子进程,这点让我迷惑,我迷惑的是循环等待应该是while语句实现的,所以我个人的理解是如果将上面的示例代码改成:
void sig_chld(int signo)
{
pid_t pid;
int stat;
while((pid=wait(&stat))>0)
printf("child %d termminated\n",pid);
return;
}
复制代码
当使用下面这个信号处理函数,却不会有僵尸进程
void sig_chld(int signo)
{
pid_t pid;
int stat;
while((pid=waitpid(-1,&stat,WNOHANG))>0)
printf("child %d termminated\n",pid);
return;
}
对比起来更容易理解 |
|