当一个父进程开启了多个管道,并且通过写的方式与多个子进程进程通信的情况下,有可能会出现以下的问题:
我明明有多个子进程,为什么在执行退出操作的时候退出失败了,并且还卡住了。
原理讲解:
这是我们理想中的管理情况,一个父进程有多个写端,对应不同的管道,与不同的子进程通信。但是我们通常会忽略了一点,子进程会继承父进程的pcd。因此,我们通常写出来的其实每个子进程都继承了父亲的写端fd,只不过他们不一定知道。就像下图所示:
第二个进程继承了第一个管道的写端,第三个进程继承了第二个和第一个的写端。
所以,当我们想利用父进程关闭写端来结束子进程时,会发现这样做一个都结束不了,因为当一个管道的所有读端都关闭了才能关闭管道。
解决方案有二:
第一种:将进程从后往前结束。
第二种:将父进程的写端记录起来,然后每次创建子进程的时候都将父进程那继承的写端关闭。