【计算机原理】进程中的fork函数

2019-04-14 17:35发布

包含头文件 < sys/types.h> 和 < unistd.h> 函数功能:创建一个子进程 函数原型 pid_t fork(void); //一次调用两次返回值,是在各自的地址空间返回,意味着现在有两个基本一样的进程在执行 参数:无参数。 返回值: 如果成功创建一个子进程,对于父进程来说返回子进程ID
如果成功创建一个子进程,对于子进程来说返回值为0
如果为-1表示创建失败
流程图:
流程图
父进程调用fork()系统调用,然后陷入内核,进行进程复制,如果成功: 1,则对调用进程即父进程来说返回值为刚产生的子进程pid,因为进程PCB没有子进程信息,父进程只能通过这样获得。 2,对子进程(刚产生的新进程),则返回0, 这时就有两个进程在接着向下执行 如果失败,则返回0,调用进程继续向下执行 注:fork英文意思:分支,fork系统调用复制产生的子进程与父进程(调用进程)基本一样:代码段+数据段+堆栈段+PCB,当前的运行环境基本一样,所以子进程在fork之后开始向下执行,而不会从头开始执行。 用python例子 import os def myfork(): pid = os.fork() if pid == 0: print "i am child ",pid else: print "i am prasents",pid 结果:
i am parsents 2948
i am child 0
这个实例充分说明了 fork函数是创建了两个进程分别执行。 原文参考:http://www.cnblogs.com/mickole/p/3186441.html