光阴过隙,很快又一个月又过去了,这次就聊聊在学习中遇到的一对“父子”。
说起这对父子,父亲有时候有点冷血,看着自己的“儿子”死了,无动于衷放任着自己儿子的尸体,不给儿子收拾体面,任由孩子僵尸着;而这“儿子”实则可怜,有时候走的不'体面'就算了,还要面临抛弃,在‘父亲’撒手人寰之后,他就会被一号福利院接管,此时开始就是一个孤儿了!!! 说到这大家应该猜到我说的这对父子是谁了吧,他们就是 Linux多任务机制下的进程的两种状态,父亲叫父进程,儿子叫子进程;两种状态为孤儿进程、僵尸进程;
孤儿进程:父进程先结束,子进程未结束,此时的子进程由福利院init(PID 1号)接管;
僵尸进程:子进程先结束,父进程未结束,并且父进程没有调用wait族函数,回收子进程的资源;
**********代码演示***********
孤儿进程:
#include "stdio.h''
int main(int argc, const char *argv[])
{
pid_t ret = fork();//只要调用fork函数,就可以创建一个子进程,子进程会从fork函数的下一行代码执行
// ret > 0
if(ret == -1)
{
perror("fork failed");//fork函数执行失败,创建子进程失败的意思
return -1; //在三秒后子进程成为孤儿;
}
else if(ret == 0)//说明当前进程是子进程
{
//子进程活着
while(1)
{
printf("我是子进程,父进程的PID是%d\n",getppid());
sleep(1);
}
}
else if(ret > 0)//说明当前进程是父进程 ,ret > 0 ,ret的值具体是几??
{
//父进程3s之后死了
printf("我是父进程,我即将走远了!!\n");
sleep(3);
printf("为父走了!!\n");
exit(0);
}
return 0;
}
**********代码演示***********
僵尸进程:
#include "my.h"
int main(int argc, const char *argv[])
{
pid_t ret = fork();//只要调用fork函数,就可以创建一个子进程,子进程会从fork函数的下一行代码执行
if(ret == -1)
{
perror("fork failed");//fork函数执行失败,创建子进程失败的意思
return -1;
}
else if(ret == 0)//说明当前进程是子进程
{
printf("子进程的PID是%d\n",getpid());
printf("子进程走了!!\n");
exit(0);//子进程结束
}
else if(ret > 0)//说明当前进程是父进程
{
//父进程活着,但有没有调用wait族函数,回收子进程的资源
while(1)
{
printf("我是父进程,我还在%d!!!\n",getpid());
sleep(1);
}
}
return 0;
}