Linux-父进程wait回收子进程】的更多相关文章

学习到wait函数了,这个函数的作用是用来回收进程.一般来说,正常退出的进程是不需要我们来专门回收的.但是进程有这两种:孤儿进程和僵尸进程. 孤儿进程: 通俗点说就是父进程先于子进程死亡.此时子进程就成为孤儿进程.这时候子进程的父进程就是init进程了.这个过程(父进程死亡后子进程的父进程变为init)称为init进程领养孤儿进程. 僵尸进程 进程终止,但是父进程并未进行回收操作.子进程的残留资源(PCB)存在于内核中,成为僵尸进程.就是儿子死了,但是父亲不收尸. 这里要注重理解的是:僵尸进程实…
1.wait工作原理 (1).子进程结束时,系统向其父进程发送SIGCHILD信号 (2).父进程调用wait函数后阻塞 (3).父进程被SIGCHILD信号唤醒然后去回收僵尸子进程 (4).父子进程之间是异步的,SIGCHILD信号机制就是为了解决父子进程之间的异步通信问题,让父进程可以及时的去回收僵尸子进程. (5).若父进程没有任何子进程则wait返回错误. 2.wait的参数status.status用来返回子进程结束时的状态,父进程通过wait得到status后,就可以知道子进程的一些…
#include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <signal.h> #include <unistd.h> void handler(int arg) { printf("receive SIGCHLD\n"); } int main(int argc, const char *argv[]) { signal(SIGCHLD,ha…
如果进程ID最大值没有达到系统进程数的上限,子进程比父进程ID大.但是如果进程ID达到上限,系统会分配之前分配但是已经退出的进程ID给新进程,这样有可能出现子进程ID比父进程小.…
首先对于fork命令  通过fork命令创建进程 父进程返回子进程id 子进程返回0 失败返回-1 对于pipe通讯机制   pipe通讯是半双工的 也就是说只能一方读一方写 题目中想要P1的输出作为P2的输入 那么就需要关闭P1的读状态描述符 思路: 创建3个子进程 创建两个pipe管道 ,P1 P2 通过pipe1通信, P2 P3通过pipe2通信 解题:…
得到进程的pid: ps -ef | grep process_name | grep -v "grep" | awk '{print $2}' 查看进程的所有线程 # ps mp 6648 -o THREAD,tid USER     %CPU PRI SCNT WCHAN  USER SYSTEM   TID root      0.0   -    - -         -      -     - root      0.0  24    - -         -    …
孤儿/僵尸进程——回收子进程 参考博客:https://blog.csdn.net/qq_35396127/article/details/78725915 :https://www.cnblogs.com/Anker/p/3271773.html 在Linux下,子进程可由父进程创建,子进程也可以创建新的进程.但是父进程无法预测子进程的运行状态,不知道子进程何时会结束.由此会产生孤儿进程与僵尸进程.所以当一个进程结束后,它的父进程需要调用wait(),waitpid()系统调用获取子进程终止状…
一.摘要 详解父进程.子进程.守护进程的区别,例子稍候补充 二.定义区别 主进程 程序执行的入口,可以理解为常用的main 函数 父进程 对于子进程而言, 子进程的创造者,可有多个子进程. 任何进程都有父进程,追根溯源是系统启动程序.对于我们一般写的程序,主进程是最初始的父进程. 子进程 对于父进程而言, 父进程创建的进程, 子进程只能对应一个父进程. 守护进程 我们常言的daemon 进程,是子进程的一种状态,标记子进程与父进程同死.如果没有标记daemon , 则杀死父进程,与子进程的运行状…
pcntl_fork创建子进程成功的话,系统就有了2个进程,一个为父进程,一个为子进程,父进程和子进程都继续向下执行,子进程的id号为$pid(父进程会获取子进程的$pid也就是$pid不为0,而子进程会获取$pid为0)在系统运行到$pid = pcntl_fork();时,在这个地方进行分支,父子进程各自开始运行各自的程序代码(通过if else语句判断$pid我们就可以在指定位置写上不同的逻辑代码). 代码的运行结果是parent 和child,很奇怪吧,为什么一个if和else互斥的代码…
僵死进程简而言之就是:子进程退出时,父进程并未对其发出的SIGCHILD信号进行适当处理,导致子进程停留在僵死状态等待其父进程为其收尸,这个状态下的子进程就是僵死进程. 在fork()/execve()过程中,假设子进程结束时父进程仍存在,而父进程fork()之前既没安装SIGCHLD信号处理函数调用waitpid()等待子进程结束,又没有显式忽略该信号,则子进程成为僵死进程,无法正常结束,此时即使是root身份kill -9也不能杀死僵死进程.补救办法是杀死僵尸进程的父进程(僵死进程的父进程必…