先了解Linux中进程的一些机制:
孤儿进程和僵尸进程:
1 如果父进程先退出,子进程尚未退出,那么子进程会成为孤儿,这时候会被init进程领养,等到子进程生命周期结束后,init会作为父进程释放掉子进程所占用的资源,所以孤儿进程并没有危害;
孤儿进程和僵尸进程:
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 <iostream>
#include <unistd.h>
#include <signal.h>
#include <sys/wait.h>
using namespace std;
void cleanUp(int sig)
{
int a; //这个变量用于保存子进程的退出码
wait(&a); //这个函数会清除子进程所占用的资源,包含于<sys/wait.h>中
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;
}