一、fork入门知识
一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
调用成功时两个返回值
1)父进程返回当前子进程pid(子进程的标识符)
2)子进程返回0(找父进程使用getppid())
调用失败返回-1。
接下来就用一个简单的例子来说明:
运行结果
分析:
子进程是父进程的副本。例如:子进程获得父进程数据空间、堆和栈的副本(主要是 数据结构的副本)。父子进程不共享
这些存储空间部分。父子进程共享正文段。 由于fork之后经常归属exec,所以现在很多实现并不执行一个父进程数据段、栈和堆的完
全复制。作为替代,使用了写时复制(Copy-On-Write)技术。代码共享,数据不共享这些区域由父子进程共享,而且内核将他们的访
问权限改变为只读的。如果父子进程中的任一个试图修改这些区域,则内核只为修改区域的那块内存制作一个副本。
二、fork进阶知识
先来看一段代码
运行结果
分析:
总结一下规律,对于这种N次循环的情况,执行printf函数的次数为2*(1+2+4+……+2N-1)次,
创建的子进程数为1+2+4+……+2N-1个。