免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4217 | 回复: 7

关于system()函数阻塞SIGCHLD信号的真正原因 [复制链接]

论坛徽章:
0
发表于 2012-04-13 16:23 |显示全部楼层
本帖最后由 lanying_wzw 于 2012-04-13 16:47 编辑

并不是不在父进程中产生SIGCHLD信号(若设置了信号句柄),而且这也无法做到,sig_procmask()函数会调用解除阻塞的信号句柄,还是会产生SIGCHLD信号!而是在发送SIGCHLD信号前让system()函数先用waitpid()处理完system()里产生的子进程(还要获取此子进程的结束状态,以便用作system()的返回值),免得在system()函数的调用者的SIGCHLD信号句柄中waitpid的时候冒出来一个不认识的pid(由system()产生),而且会影响system()函数,得不到子进程的结束状态(被system()调用者的SIGCHLD处理函数给处理了)!
这一点APUE上说的不是特别清楚,只是说为了防止影响system()调用者,其实我觉得最重要的原因是影响system()的返回值(子进程的执行状态)!

论坛徽章:
0
发表于 2012-04-13 16:46 |显示全部楼层
“system()函数的调用者的SIGCHLD信号句柄中waitpid的时候冒出来一个不认识的pid”

只要child不被reaped,就不会“不认识”的。
这个限制条件是为了防止父进程对sigchld设了sig_ign,导致(可能)在waitpid前接到sigchld,reap child后waitpid出错。

论坛徽章:
0
发表于 2012-04-13 16:51 |显示全部楼层
回复 2# 鸡丝拌面


    我觉得不是,我已经修改了帖子,你重新看一下,SIGIGN的问题我倒是没考虑

论坛徽章:
0
发表于 2012-04-13 16:52 |显示全部楼层
lanying_wzw 发表于 2012-04-13 16:51
回复 2# 鸡丝拌面



如果先收到sigchld,然后reap,waitpid就出错了。

论坛徽章:
0
发表于 2012-04-13 16:55 |显示全部楼层
回复 4# 鸡丝拌面


    没听懂你的意思,能否说详细些?再说waitpid()可以是个循环

论坛徽章:
0
发表于 2012-04-13 16:59 |显示全部楼层
lanying_wzw 发表于 2012-04-13 16:55
回复 4# 鸡丝拌面


POSIX.1-2001 allows a parent process to elect for the kernel to automatically reap child processes that terminate by setting the disposition of SIGCHLD to SIG_IGN (which is the default) or by setting the SA_NOCLDWAIT flag for the SIGCHLD signal。
如果这样,sigchld处理返回后子进程就木有了,然后waitpid通过子进程的pid能找到啥?所以出错,错误码ECHILD。

论坛徽章:
0
发表于 2012-04-13 18:02 |显示全部楼层
回复 6# 鸡丝拌面


    我表达的意思其实就是一句话,system()阻塞SIGCHLD信号的目的是为了先waitpid()得到子进程的状态(system()的返回值),再产生信号(如果进程设置产生信号的话)

论坛徽章:
0
发表于 2012-04-13 18:09 |显示全部楼层
回复 4# 鸡丝拌面


    没错,这样就得不到子进程的执行状态了,我想说的是system()函数之所以阻塞SIGCHLD,是防止system()函数得不到子进程的状态,而不是防止调用信号处理函数。这个跟设置SIGCHLD的句柄为SIGIGN没什么关系吧?如果设置了,system()函数执行也会报错的!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP