消息关闭
    暂无新消息!

关于SIGCHLD的一点疑问

问题作者 : 潇雨2017-08-10发布
关于SIGCHLD的一点疑问
sigchld
下面这段程序:
void sig_handler(int sig)
{
switch(sig){
case SIGPIPE:
printf("Get SIGPIPE signal:reader does not exist\n");
case SIGCHLD:
printf("Get SIGCHLD signal:child exits\n");
}
}
int main()
{
pid_t pid;
char data[32] = "hello";
int fds[2]; 
signal(SIGCHLD,sig_handler);//设置当前进程对对SIGCHLD信号捕捉函数
if(pipe(fds) == 0){
    pid = fork(); 
    if(pid == 0){
    printf("Child is waiting 2s for closing pipereadend of parent\n");
    sleep(2);
    close(fds[0]);//关闭子进程管道读端
        signal(SIGCHLD,SIG_DFL);//设置子进程对SIGCHLD信号默认处理方式
        signal(SIGPIPE,sig_handler);//设置子进程对SIGPIPE信号捕捉函数
        write(fds[1],data,strlen(data));//子进程写data进入管道

    }else if(pid > 0){
    close(fds[0]);//关闭父进程管道读端
        wait(NULL);
        }
}
return 0;
}
执行结果为
Child is waiting 2s for closing pipereadend of parent
Get SIGPIPE signal:reader does not exist
Get SIGCHLD signal:child exits
Get SIGCHLD signal:child exits
我的疑问是为什么这个程序里子进程会给父进程发两次SIGCHLD信号?触法执行了两次_sig_handler函数. SIGCHLD信号不是应该子进程结束终止时才给父进程发吗?那这个地方另外一次是什么时候发的?难道是子进程收到SIGPIPE信号执行了函数后就终止了?_

3个回答

︿ 3

void sig_handler(int sig)
{
switch(sig){
case SIGPIPE:
printf("Get SIGPIPE signal:reader does not exist\n");
case SIGCHLD:
printf("Get SIGCHLD signal:child exits\n");
}
}


这里的switch ...case没有break语句, 当有信号SIGPIPE时也会往下执行printf("Get SIGCHLD signal:child exits\n");
︿ 0
这是我打印 pid 的结果,明显有一次是子进程处理的。
Get SIGPIPE signal:reader does not exist
child id is -1, stat is 1
pid is 22209
Get SIGCHLD signal:child exits
child id is 22209, stat is 0
pid is 22208
Get SIGCHLD signal:child exits

所以,子进程不应该再调用 signal了。可以在信号处理函数中视情况再调 signal。