僵尸进程与孤儿进程

来源:互联网 发布:网络结婚游戏 编辑:程序博客网 时间:2024/05/24 06:10

子进程是通过父进程创建的,子进程在创建新的进程。子进程的结束和父进程的运行是一个异步过程,即父进程永远无法预测子进程 到底什么时候结束。 当一个 进程完成它的工作终止之后,它的父进程需要调用wait()或者waitpid()系统调用取得子进程的终止状态。

  • 僵尸进程(父进程在,子进程不在,子进程就是僵尸)

    一个进程使用fork创建子进程,如果子进程退出,而父进程并没有调用wait或waitpid获取子进程的状态信息,那么子进程的进程描述符仍然保存在系统中。这种进程称之为僵尸进程

    我们来看下面的例子

#include<stdio.h>#include<unistd.h>#include<stdlib.h>int main(){    pid_t pid=fork();    if(pid>0)//father    {        while(1)        {          printf("father pid is: %d\n",getpid());          sleep(1);        }    }    else if(pid==0)//child    {       printf("child pid is :%d\n",getpid());//子进程退出       exit(0);    }    return 0;}

结果如图:
这里写图片描述

我们重新打开一个终端就可以看它是一个僵尸状态

这里写图片描述

  • 孤儿进程(父进程不在,子进程在,孤儿进程交给1号进程(孤儿院))

    一个父进程退出,而它的一个或多个子进程还在运行,那么那些子进程将成为孤儿进程。孤儿进程将被init进程(进程号为1)所收养,并由init进程对它们完成状态收集工作。

僵尸进程会引起资源浪费,而孤儿进程不会。

下面我们来看关于孤儿进程的实例:

#include<stdio.h>#include<unistd.h>#include<stdlib.h>int main(){    pid_t pid=fork();    if(pid==0)//child    {       printf("i am child,pid:%d,ppid:%d\n",getpid(),getppid());       sleep(2);    }    else if(pid>0)//father    {       printf("i am father,pid:%d\n",getpid());       printf("father quit!\n");    }    return 0;}

输出结果如图:

这里写图片描述

原创粉丝点击