提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
APUE两次fork防止产生僵尸进程的例程相关——子进程没有被init收留的问题
一、问题
首先看书上的例程与结果
![请添加图片描述](https://img-blog.csdnimg.cn/671e8b287e1c4d35b85fd8c4d2356794.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5aSc5Y2K6Imv6L6w,size_20,color_FFFFFF,t_70,g_se,x_16)
按道理来说,第一个子进程被收掉之后,第二个子进程会被init进程收留,书上写的很明显了。
然后看我的程序与结果。
![请添加图片描述](https://img-blog.csdnimg.cn/44acf852d74a4607a858d37c5580fce4.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5aSc5Y2K6Imv6L6w,size_20,color_FFFFFF,t_70,g_se,x_16)
![请添加图片描述](https://img-blog.csdnimg.cn/0dedcc6e693d496db4564b8d74a8d4f8.png)
不论复现多少次,第二个子进程都被pid为1516的进程收留,而不是init进程。
pid为1516的进程是什么呢?![在这里插入图片描述](https://img-blog.csdnimg.cn/658f0d82abdd40728a069f22daa6eefb.png)
是/lib/systemd/systemd --user。这也就有一个可能,随着linux版本更新或者gcc等更新,有些标准可能就变了。
二、证明
代码如下:
![请添加图片描述](https://img-blog.csdnimg.cn/dfcedf3505934459babd129c0cdebf52.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5aSc5Y2K6Imv6L6w,size_20,color_FFFFFF,t_70,g_se,x_16)
可以看到,(sleep调用前)第二个子进程的pid为59676,ppid为59675,而且ppid与第一个子进程的pid相同,确实符合fork函数的描述。然后由于第一个子进程调用了exit(0)退出了,然后被waitpid接收,那么第二个子进程就成了僵尸进程,同时也是个孤儿进程,因为没有第一个子进程waitpid它了。于是在调用完sleep后,第二个子进程发现自己的父进程没了,于是应该由init进程收留它,可能是因为版本变化,现在改为/lib/systemd/systemd来收留它了,由此记录。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)