僵死进程

僵死进程

1、产生原因
     进程主体结束,但是其 PCB 没有释放
     PCB 中记录进程的运行信息,进程结束时,PCB 中有一个 exit_code,保存进程的退出信息,进程退出信息如果没有被(父进程)处理,则 PCB 无法释放
     子进程结束,父进程未结束并且父进程未获取(处理)子进程的退出状态,从而子进程不得不保存退出码,所以整个 PCB 就无法释放
父进程可以获取子进程的退出码

int main()
{
	pid_t pid=fork();
	assert(pid!=-1);
	int n=0;
	char *s=NULL;
	//子进程
	if(pid==0)
	{
		n=0;
		s="child pid";
	}
	//父进程
	else
	{
		n=5;
		s="---father----";	
		/*
		while(1)
		{
			sleep(2);
			printf("---father----\n");	
			printf("father pid=%d,ppid=%d\n",getpid(),getppid());
		}*/
	}
	int i=0;
	for(;i<n;i++)
	{
		printf("%s,%d,father pid=%d,ppid=%d\n",s,i,getpid(),getppid());
		sleep(2);
	}
	return 0;
}

查找僵尸进程

ps aux|grep defunct

在这里插入图片描述

父进程如何处理子进程的退出状态:

     用 wait 函数将调用者阻塞,直到某个子进程终结,故父进程可调用 wait 函数回收其僵尸子进程。
阻塞运行:函数调用,只要条件不满足,则函数不成立
非阻塞运行:函数调用,无论任何情况,函数都会立即返回

1、wait
pid_t wait( int *reval); 阻塞
调用一次,只能处理一个子进程的僵死状态
wait 函数会阻塞,直到任意一个子进程结束
返回值:-1,回收失败,已经没有子进程了
              >0,回收是子进程对应的 pid
reval:获取到子进程的退出码

void fun(int sign)
{
	pid_t pid=wait(NULL);
	printf("pid=%d\n",pid);
}

int main()
{
	signal(SIGCHLD,fun);
	pid_t n=fork();
	assert(n!=-1);

	if(n==0)
	{
		printf("child start:%d\n",getpid());
		sleep(2);
		printf("chile over\n");
	}
	else
	{
		printf("father start:\n");
		while(1)
		{
			sleep(1);
			printf("father running\n");
		}
		sleep(100);
		printf("father over\n");
	}
}

2、waitpid
    如果在调用 waitpid() 函数时,当指定等待的子进程已经停止运行或结束了,则 waitpid() 会立即返回;但是如果子进程还没有停止运行或结束,则调用 waitpid() 函数的父进程则会被阻塞,暂停运行。

pid_t waitpid( pid_t pid, int *reval, int flag); 非阻塞
pid:
     pid > 0 某个子进程的 pid
     pid == -1 回收所有的子进程
         循环回收
         while((wpid = waitpid(-1, &status, WNOHANG)));
     pid == 0 回收当前进程组所有的子进程
     pid < 0 子进程的 pid 取反(加减号)
flag
     0 阻塞
     WNOHANG 非阻塞

返回值:
     -1 回收失败
     >0 回收子进程的 pid
     如果为非阻塞 =0:子进程处于运行状态

### 回答1: 在 Linux 中,进程可能是僵尸进程僵死进程僵尸进程是一种已经结束运行但还没有被父进程回收的进程。当父进程没有调用 wait 或 waitpid 函数来回收子进程的结束状态时,子进程就会成为僵尸进程僵尸进程在系统中仍占用一些资源,但是它的代码已经不会再被执行。 僵死进程是一种无法再终止的进程。当一个进程的父进程已经终止,而这个进程没有被重新分配给其他的父进程时,它就成为了僵死进程僵死进程不会占用系统资源,但是它仍然占用着进程表中的一个项目。 ### 回答2: 在Linux中,进程既可以是僵尸进程(zombie process)也可以是僵死进程(dead process)。 僵尸进程是指一个子进程已经结束运行,但是父进程还没有处理该子进程的终止状态信息。这种状态下的子进程会被内核保留,并在进程表中记录一段时间。僵尸进程不占用系统的资源,但是会占用一个进程ID(PID),因此如果有大量僵尸进程存在,可能会导致系统PID耗尽。处理僵尸进程的常见方法是父进程调用wait或waitpid函数来处理子进程的状态,释放其资源,并将其从进程表中删除。 僵死进程是指一个进程已经终止运行并且无法正常释放资源。这可能是因为进程在结束时未正确释放资源的问题,或者由于系统故障导致进程被异常终止。僵死进程会一直占用系统的资源,包括内存和文件描述符等。要解决僵死进程,可以通过重启系统来清除它们,或者通过手动终止占用资源的进程来释放资源。 因此,Linux中既存在僵尸进程又存在僵死进程僵尸进程是指子进程结束但父进程未处理的进程状态信息,而僵死进程是指已经结束但无法正常释放资源的进程。处理僵尸进程需要父进程主动回收子进程,而对于僵死进程通常需要进行系统重启或手动终止进程来解决。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值