本文档的Copyleft归rosetta所有,使用GPL发布,可以自由拷贝、转载,转载时请保持文档的完整性。
参考资料:APUE2e
来源:http://blog.csdn.net/rosetta
一个进程如果终止后未被其父进程回收,它将仍然占用资源,这种进程称为僵尸进程(zombie),它将对系统产生危害。
可以通过ps -aux查看系统中是否存在僵尸进程(其状态显示为Z)。
为避免产生僵尸进程,可以通过两次fork()操作,第一次fork产生第一个子进程,第二次fork由第一个子进程产生第二个子进程,目前的状态变成:爷爷->父亲->孙子。爷爷回收父亲后退出,此时孙子的父进程自动托管给init进程。而init进程无论如何会回收子进程的,所以这样就不会产生僵尸进程了。
一、两个系统调用
#include <sys/types.h>
#include <unistd.h>
pid_t fork(void);
创建一个新进程
父进程返回值是子进程的pid
子进程返回值为0
出错返回-1
#include <sys/types.h>
#include <sys/wait.h>
pid_t wait(int *status);
pid_t waitpid(pid_t pid, int *status, int op
参考资料:APUE2e
来源:http://blog.csdn.net/rosetta
一个进程如果终止后未被其父进程回收,它将仍然占用资源,这种进程称为僵尸进程(zombie),它将对系统产生危害。
可以通过ps -aux查看系统中是否存在僵尸进程(其状态显示为Z)。
为避免产生僵尸进程,可以通过两次fork()操作,第一次fork产生第一个子进程,第二次fork由第一个子进程产生第二个子进程,目前的状态变成:爷爷->父亲->孙子。爷爷回收父亲后退出,此时孙子的父进程自动托管给init进程。而init进程无论如何会回收子进程的,所以这样就不会产生僵尸进程了。
一、两个系统调用
#include <sys/types.h>
#include <unistd.h>
pid_t fork(void);
创建一个新进程
父进程返回值是子进程的pid
子进程返回值为0
出错返回-1
#include <sys/types.h>
#include <sys/wait.h>
pid_t wait(int *status);
pid_t waitpid(pid_t pid, int *status, int op