用wait和waitpid函数清理僵尸进程,父进程可以阻塞等待子进程结束,也可以非阻塞地查询是否有子进程结束等待清理(也就是轮询的方式)。采用第一种方式,父进程阻塞了就不能处理自己的工作了;采用第二种方式,父进程在处理自己的工作的同时还要记得时不时地轮询一下,程序实现复杂。
其实,子进程在终止时会给父进程发SIGCHLD信号,该信号的默认处理动作是忽略,父进程可以自定义SIGCHLD信号的处理函数,这样父进程只需专心处理自己的工作,不必关心子进程了,子进程终止时会通知父进程,父进程在信号处理函数中调用wait清理子进程即可。
编写一个程序:父进程fork出子进程,子进程调用exit(2)终止,父进程自定义SIGCHLD信号的处理函数,在其中调用wait获得子进程的退出状态并打印。
#include "./common/head.h" /*功能: *子进程正常死亡(exit),发出SIGCHLD信号;父进程绑定该信号的处理函数,给它收尸。 */ //父进程给子进程收尸的处理函数 void sig_child(int signo){ int sts; pid_t pid = wait(&sts); if(WIFEXITED(sts)){ //子进程正常死亡 printf("proc:%d exit with code %d\n", pid, WEXITSTATUS(sts)); } return ; } int main() { pid_t pid = fork(); if(pid < 0){ perror("f
关于SIGCHLD信号
最新推荐文章于 2024-02-15 22:16:28 发布
本文介绍了如何使用wait和waitpid函数处理Linux系统中的僵尸进程,讨论了父进程在处理子进程结束时的不同策略。重点讲解了SIGCHLD信号的作用,即子进程终止时会发送给父进程,允许父进程在信号处理函数中调用wait进行清理。此外,还提到了通过设置SIGCHLD信号处理动作为SIG_IGN,让子进程自动清理,避免僵尸进程的产生,并通过编写程序验证了这种方法在Linux上的效果。
摘要由CSDN通过智能技术生成