当我们使用创建进程的函数fork(),vfork()等,创建了子进程
1.子进程先于父亲进程退出,会造成子进程的进程编号无法释放.(进程编号的范围很大,但不应该随意浪费)
2.子进程后于父亲进程退出,子进程会交给init()进程管理.
3.一个进程在执行完毕后,系统会自动清空其存在的进程的相关资源
结合上面说明,一个僵死进程的例子.
#include <stdio.h>
#include <sys/types.h>
int main(){
pid_t p=fork();
if(p<0){
perror("for create a processor!");
return -1;
}else if(p>0){
sleep(1);
system("ps u");
}
return 0;
}
我们创建的僵死进程后面还出现了一个defunc(死人,僵尸)的标号
创建一个孤儿进程
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
int main(){
pid_t pid;
pid = fork();
if(pid > 0){
sleep(1);
exit(3);
}else if(pid == 0){
printf("before:PID:%d,PPID:%d\n", getpid(), getppid());
sleep(3);
//printf("after:PID:%d,PPID:%d\n", getpid(), getppid());
system("ps -ef");
}
}
你会发现第二次输出的子进程已经交给init()进程托管了.