用signal函数处理父进程创建的多个子进程,避免僵死进程的产生

本文介绍了如何使用wait和signal函数在父进程中有效地处理多个子进程,避免产生僵死进程。通过设置wait参数和使用signal函数,父进程可以在不阻塞自身的情况下,及时获取子进程的退出信息并清理僵尸进程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当一个子进程结束退出时   它面临三种情况。
1  它的父进程中有对它结束的等待处理机制  (wait 或者 waitpid 函数)  子进程如愿以偿的成功结束 并销毁它的PCB
2  它的父进程没有等待获取子进程的退出码   这时候  子进程的进程主体虽已被释放  但是PCB 并没有  ,这个子进程就变成僵死进程
3  子进程在结束时甚至还未结束前  它的父进程就退出了  ,这个子进程就变成孤儿进程  ,将由 init进程收养  ,并wait这个孤儿退出 结束 ,替他善后。
情况一是正常情况,情况三虽然听上去蛮可怜,但也并没有危害,反而是 情况二:僵死进程   (我不确定是僵尸进程还是僵死进程)这个比较难处理,
子进程的PCB不被释放,那其进程号就会一直被占用, 但是系统所能使用的进程号是有限的,如果大量的僵死进程产生,没有可用的进程号将会导致系统不能产生新进程。
目前问题就是:如何避免僵死进程    ,也就是 在父进程中 如何获取子进程的退出码
上文已经说过  有两个函数可以解决这个问题  ,接下来介绍 wait()以及waitpid()函数:

#include <sys/types.h>

#include <sys/wait.h>

pid_t wait(int *status);

pid_t waitpid(pid_t pid, int *status, int options);

参数status用来保存被收集进程退出时的一些状态,它是一个指向int类型的指针。但如果我们对这个子进程是如何死掉的毫不在意,只想把这个僵尸进程消灭掉,我们就可以设定这个参数为NULL,就象下面这样:pid = wait(NULL);

返回值是子进程的pid  ,一次调用wait  只会处理一个子进程,返回一个子进程的pid ,如果 父进程创建了多个子进程,那么就需要调用多次wait ,但是问题是,进程一旦调用了wait,就立即阻塞自己&#

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值