Linux系统编程————孤儿进程与僵死进程

孤儿进程

父进程先于子进程结束,子进程则称为孤儿进程。

 原因: 

        1、进程结束后,都会释放自己所占的用户空间;
        2、但是进程的pcb必须由父进程来释放;
        3、孤儿进程被系统进程init领养,释放孤儿进程的pcb。

 

孤儿进程例子:

int main()//孤儿进程
{
	pid_t pid;
	
	pid = fork();
	if(pid == 0)
	{
		sleep(1);//子进程睡眠一秒,父进程肯定先于子进程结束
		printf("child_pid=%d,ppid=%d\n",getpid(),getppid());
	}
	else if(pid > 0)
	{
		printf("parent_pid=%d\n",getpid());
	}
	return 0;
}

解决办法/危害:

由于父进程已经死亡,系统会帮助父进程回收处理孤儿进程。

所以孤儿进程实际上是不占用资源的,因为它终究是被系统回收了。

不会像僵尸进程那样占用ID,损害运行系统。

僵尸进程

子进程先于父进程结束,子进程则成为僵尸进程。

原因:

1、僵尸进程是已经死掉的进程,但是它的pcb还存活在内存中;
           2、子进程退出时,父进程没有及时调用wait获取子进程的退出码,释放子进程的pcb。


注意:      

        僵尸进程不能用kill命令杀死,因为它是一个死了的进程。

僵尸进程例子:

int main()//僵尸进程
{
	pid_t pid;
	
	pid = fork();
	if(pid == 0)
	{
		printf("child_pid=%d,ppid=%d\n",getpid(),getppid());
	}
	else if(pid > 0)
	{
		while(1)//让父进程一直忙于别的事,无暇顾及子进程。
		{
			printf("parent_pid=%d\n",getpid());
			sleep(1);
		}
	}
	return 0;
}

解决办法/危害:

         占用内存和ID
         1、用信号杀死它的父进程,则僵尸进程(此时就成了孤儿)就会被init领养,释放它的pcb。(kill -9 父进程pid)

         2、在父进程中调用wait方法,等待子进程结束,获取子进程的退出码。(详情见:https://blog.csdn.net/djh971102/article/details/97816681

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值