在linux中,fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,
也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。
下面有如下代码:
int main()
{
int i = 0;
for(; i < 2; ++i)
{
if(fork())
{
printf(“A\n”);
}
else
{
printf(“B\n”);
}
}
}
分析输出结果,并指出为何有这种结果?
在linux上运行后,会得到3个A和3个B。顺序并不能确定。
具体分析:
第一趟:i=0时。
原进程标记为1,打印A,。
fork出来的子进程标记为2,返回值为0,打印B。
此时有两个进程,且在下一轮i同时++。
第二趟:i=1时。
进程1和2分别做为父进程,产生2个子进程,记为3,4.
进程1此时作为父进程再次打印A。
进程3是进程1在i=1时产生的新的子进程,将打印B。
进程2之前是进程1的子进程,而在i=1这一轮循环中,作为进程4的父进程存在,所以打印A。
进程4只是子进程,打印B。
即,进程1打印AA,进程2打印BA,进程3,4都只打印B,最终结果是3个A,3个B。