目录
1. 僵尸进程
2. 孤儿进程
1. 僵尸进程
僵尸状态:一个进程已经退出,但是还不允许被OS释放,处于一个被检测的状态。
僵死状态(Z-
Zombies
)是一个比较特殊的状态。当
子进程退出并且父进程没有读取到子进程退出的返回代码时就会产生
僵死(尸)进程
- 僵死进程会以终止状态保持在进程表中,并且会一直在等待父进程读取退出状态代码。
- 所以,只要子进程退出,父进程还在运行,但父进程没有读取子进程状态,子进程进入Z状态
来一个创建维持30秒的僵死进程例子:
int main()
{
pid_t id = fork();
if(id < 0)
{
perror("fork");
return 1;
}
else if(id > 0)//parent
{
printf("parent[%d] is sleeping...\n", getpid());
sleep(30);
}
else//id==0,child
{
printf("child[%d] is begin Z...\n", getpid());
sleep(5);
exit(EXIT_SUCCESS);
}
return 0;
}
僵尸进程危害
- 进程的退出状态必须被维持下去,因为他要告诉关心它的进程(父进程),你交给我的任务,我办的怎么样了。可父进程如果一直不读取,那子进程就一直处于Z状态!
- 维护退出状态本身就是要用数据维护,也属于进程基本信息,所以保存在task_struct(PCB)中,换句话说,Z状态一直不退出,PCB一直都要维护!
- 那一个父进程创建了很多子进程,就是不回收,是不是就会造成内存资源的浪费?是的!因为数据结构对象本身就要占用内存.内存泄漏?是的!
- 如何避免?以后回收僵尸进程博客写了会把链接拉过来。
2. 孤儿进程
- 父进程如果提前退出,那么子进程后退出,进入Z之后,那该如何处理呢?
- 父进程先退出,子进程就称之为“孤儿进程”
- 孤儿进程被1号init进程领养,当然要有init进程回收喽。
孤儿进程为什么要被领养?未来子进程退出的时候,父进程早已不在,需要领养进程来进行回收
实现一个孤儿进程:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int main()
{
pid_t id = fork();
if(id < 0)
{
perror("fork");
return 1;
}
else if(id == 0)//child
{
printf("I am child, pid : %d\n", getpid());
sleep(10);
}
else//parent
{
printf("I am parent, pid: %d\n", getpid());
sleep(3);
exit(0);//父进程退出,使子进程成为孤儿进程
}
return 0;
}