Linux中fork()函数案例分析

在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。





猜你喜欢

转载自blog.csdn.net/czc1997/article/details/78306645