Linux系统下循环fork所产生的进程数量

我们知道fork函数可以创建一个新进程,那当fork和循环一起使用的时候会发生什么情况。

为了方便查看进程数量,我们在fork的同时打印A,分析A的数量就可知有多少个进程。

情景1(循环2次,先fork后打印)

 程序代码如图所示,运行结果如下图:

可以看到,总打印出来了6个A,为什么是6个A呢?6个A就是6个进程吗?

其实并不是,因为我们是先fork后打印。所以,在第1次循环,第1次打印A的时候,已经有一个增生的进程了,所以第1次打印共打印出2个A。在第2次循环的时候,最开始的进程与增生的进程各自又增生了一个进程,所以当前共有4个进程,打印出来了4个A。共有6个A。可以用图来表示。

 情景2(循环三次,先fork后打印)

统计分析循环三次可知,共打印了14次,所以共产生了8个进程。

至此,我们可以统计出规律,当循环n次时,共有2^n个进程。共打印了2^1+2^2+……+2^n个A。

 

 

情景3(循环两次,先打印,在fork)

 

因为最后一次fork之前已经进行打印了,所以最后一次fork的同时没有打印。

所以共有2^n个进程。共打印了2^0+2^1+2^2+……2^(n-1)个A。

情景4(循环两次,先fork,后打印,打印没有刷新缓冲区)

 

 运行结果如下图所示:

可以看到共打印了8个A,那共产生了多少进程呢!当然还是产生了4个,即2^n个。那为什么会打印8个呢,是因为fork在拷贝的时候将printf的缓冲区也拷贝走了(可参考我的博客输入输出缓冲区),在程序结束的时候才进行打印,所以4个进程共打印了8个

  • 11
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值