LinuxC/C++编程(3)—异步清理子进程(避免成为僵尸进程)

先了解Linux中进程的一些机制:

孤儿进程和僵尸进程:
1 如果父进程先退出,子进程尚未退出,那么子进程会成为孤儿,这时候会被init进程领养,等到子进程生命周期结束后,init会作为父进程释放掉子进程所占用的资源,所以孤儿进程并没有危害;

2 如果子进程先退出,父进程尚未退出,父进程必须调用wait()函数释放掉子进程所占用的资源,如果没有这样做,子进程的资源将不会自动释放,成为僵尸进程。Linux中,父进程可以在主线程中用wait()等待子进程结束,但是这样父进程会被阻塞,Linux中子进程退出时会给父进程自动发送一个SIGCHLD信号,于是父进程只要在接收到该信号时,调用wait清理子进程即可,这就是Linux 的“父进程异步清理子进程”;


PS:一个进程所占有的资源有:地址空间、全局变量、打开的文件、子进程、信号和信号处理程序 和 账户信息。僵尸进程将会占用着这些资源不释放。


直接贴代码:

//============================================================================
// Name        : CleanSubProcess.cpp
// Author      : Lin
// Version     :
// Copyright   : Your copyright notice
// Description : Kill Child Parent
//============================================================================

#include 
#include 
#include 
#include 

using namespace std;


void cleanUp(int sig)
{
	int a; //这个变量用于保存子进程的退出码
	wait(&a); //这个函数会清除子进程所占用的资源,包含于中
	cout << "The parent process has kill the child process successfully!" << endl;
	cout << "The exit num of child process is " << a << endl;
}

/**********设置进程对于SIGCHLD信号的相应*********/
void sigClean()
{
	struct sigaction act, oldact;
	act.sa_handler  = cleanUp;
	sigaction(SIGCHLD,&act,&oldact); //Linux中,子进程退出的时候将自动向父进程发送SIGCHLD信号
}

int main() {
	sigClean();
	pid_t pid = fork();
	if (pid != 0)
	{
		cout << "I'm the parent process!" << endl;
		sleep(10); //休眠10秒,保证子进程先退出,如果父进程不释放子进程的资源,那子进程会成为僵尸进程
	}
	else
	{
		cout << "I'm the child process!" << endl;
	}
	return 0;
}


你可能感兴趣的:(Linux,C/C++,编程)