{
Close(listenfd);
str_echo(connfd);
exit(0);
}
应该在主进程中关闭connfd套接字
close(connfd) 当时看明白了现在忘了,信号处理函数里有循环也就是函数2可以一次处理掉所有的进程,信号处理函数没有循环也就是函数1只能处理一个进程,剩下的就成了僵尸进程吧! 当SIGCHLD处理函数被调用的时候,SIGCHLD 会被临时堵塞(临时)
等函数返回又不阻塞了 处理僵尸进程的简单的方法就是二次fork....
简单 有效.. 处理僵尸进程的简单的方法就是二次fork....
简单 有效..
hanzhenlll 发表于 2011-11-14 10:46 http://bbs.chinaunix.net/images/common/back.gif
UP:em27: 其实我最近也在看这本书,心里话,觉得这本书的逻辑结构不是很好,尽管知识很详细,但是过于凌乱,不适合系统学习,当作补充还可以。楼主所提的文档我当时也搞不懂,后来去网上查了下,其实应该是这样的 :
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;
}
对比起来更容易理解
页:
[1]