学习pid进程以及fork()

学习linux期间,看到一个语句  pid_t pid = fork();

想要理解pid_t 与 fork() 的意义为何。

pid_t是一个数据类型,定义的类型是进程号id,fork()函数则返回一个id号

pid_t需要头文件 <sys/types.h> 支持

分析一波

学习pid进程以及fork()

 

 

 

 

运行结果如下图

 

学习pid进程以及fork()

 

 运行发现,在执行了上面7次后,又运行了两次

从运行结果开始分析fork()

1)父进程初始化

2)父进程调用了fork(),fork为系统调用,进入内核

3)内核根据父进程复制一个子进程,父子两个进程信息一样,代码和数据也相同,所以都会执行接下来的语句,如图

学习pid进程以及fork()

 

 4)两个进程都进入内核然后等待从内核中返回,但是究竟是父进程先返回还是子进程先返回呢,就取决于内核的调度算法了

5)当父进程被调度时,pid变量被fork()赋予的值是子进程的id,是大于0的,所以就调用第二个message赋值,并执行3次for循环

6)如果某时刻子进程被调用了,就会从内核中被返回,返回的值是0,就会执行第一个message赋值,并执行6次for循环。(在这个过程中,两个进程对于message与n变量的赋值是互不影响的)

7)父进程打印一次睡眠1秒,在这1秒中子进程很可能被调度,子进程打印一次也休眠1秒,又有可能调度父进程,所以基本上是父子进程轮流调度打印。如果将sleep去掉,结果是:

学习pid进程以及fork()

 

 就会发现是父进程执行结束后子进程才有被调度的空间

8)这个程序是在shell下运行的,shell也是一个进程,而且是父进程的父进程,在父进程结束之后,shell会认为进程结束了,然后打印shell提示符,然而此时子进程还在运行,所以才会在shell提示符后输出信息

 

总结:

fork()函数的特点是“调用一次,返回两次,父进程中调用一次,父子进程中返回两次,本来是一个控制流程的程序,在调用fork()函数之后会裂开变为两个控制流程,'fork'为“派生、分支”,父进程的fork返回的是子进程的id,子进程中的fork返回的是0

 

12/12/20 DJ

 

以上是 学习pid进程以及fork() 的全部内容, 来源链接: utcz.com/a/76126.html

回到顶部