linux系统调用函数心得:fork()

本文适用范围

1.了解fork()的主要功能
2.已阅读man fork
3.尚未进行深入探究
4.在运用过程中对一些细节产生疑惑

今天希望能编写自己的shell程序,练习并探索fork()的用法。
下面一些心得体会。

我把这些心得体会按照进程创建-destroy 的方式描述。

所有非特别标注的心得都是原创

我认为是这样

一.父进程P1调用fork()

二.子进程P2生成,由new - ready

其间,各种变量继承和初始化。此时,P2的所有变量和P1公用。除了pid,pid是不同物理地址(相同逻辑地址)的两个变量。

三.父进程和子进程开始执行

父子进程在等待queue里的先后顺序比较随机,依赖操作系统的短程调度 调度算法。
如果执行时子进程变量值改变,则该变量不再与P1共享地址,自动复制,并改变值。
此时,该变量虚拟地址与P1的相同,物理地址不同。
这是linux写时复制机制。
我猜呢,是因为资源有限而设定的。

四.进程结束情况

父进程运行,子进程运行。一般情况下有以下几种可能:

1.P1 P2在时间片轮转前就运行结束
(1)P1结束 P2未结束
P2强行结束 程序结束返回控制台
(2)P2结束 P1未结束
继续按照顺序运行
2.P1 P2均在时间片轮转前未运行结束
(1)没有等待函数
P1运行一半,转到P2,P2运行一半,自动堵塞,转到P1,因为P1没有等待机制,一直执行到结束并返还控制台;除非又轮到时间片,自己堵塞起来,P2才拥有再一次运行机会。
(2)有等待函数
等待机制函数:waitpid(pid,NULL,0);
P1运行一半,转到P2,P2运行一半,自动堵塞,转到P1,因为P1有等待机制,强制等待P2执行结束,自己堵塞起来,P2拥有全部运行到结束的机会。

你可能感兴趣的:(linux系统调用)