gswen 发表于 2011-10-23 00:44

甄|后 发表于 2011-10-23 21:40

你的子进程不会再生成子进程吗?

snowslow 发表于 2011-10-30 18:02

if((childpid=Fork())==0)
                {
                        Close(listenfd);
                        str_echo(connfd);
                        exit(0);
                }
应该在主进程中关闭connfd套接字
close(connfd)

03xsxmj 发表于 2011-11-13 16:16

当时看明白了现在忘了,信号处理函数里有循环也就是函数2可以一次处理掉所有的进程,信号处理函数没有循环也就是函数1只能处理一个进程,剩下的就成了僵尸进程吧!

cai120120-pb 发表于 2011-11-13 22:42

当SIGCHLD处理函数被调用的时候,SIGCHLD 会被临时堵塞(临时)
等函数返回又不阻塞了

hanzhenlll 发表于 2011-11-14 10:46

处理僵尸进程的简单的方法就是二次fork....
简单 有效..

lexken 发表于 2011-11-14 14:28

处理僵尸进程的简单的方法就是二次fork....
简单 有效..
hanzhenlll 发表于 2011-11-14 10:46 http://bbs.chinaunix.net/images/common/back.gif


    UP:em27:

wfade4444 发表于 2012-09-28 13:42

其实我最近也在看这本书,心里话,觉得这本书的逻辑结构不是很好,尽管知识很详细,但是过于凌乱,不适合系统学习,当作补充还可以。楼主所提的文档我当时也搞不懂,后来去网上查了下,其实应该是这样的 :
    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]
查看完整版本: unix网络编程