深入理解计算机系统系列07

fork()函数

关于fork()函数的几个例题
我们都知道fork()一次调用两次返回,当fork()函数被调用的时候,父进程把代码和数据复制给子进程

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void){
	int i;
	for(i=0;i<2;i++){
		fork();
		printf("*\n");
	}
	return 0;
}

此时画进程图可以得知,显然是有6颗*

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void){
	int i;
	for(i=0;i<2;i++){
		fork();
		printf("*");
	}
	return 0;
}

而这种情况时,打眼看过去也许会以为和上一个程序没有什么差别,但实际上运行结果是8颗星,(注意前面有两颗)(注意,前面有两颗)
但是这究竟是为什么那?
实际上,这是因为当父进程fork的时候会将堆栈,缓冲区内的数据都复制给子进程,而\n是可以清空缓冲区的,但是单纯的printf("");会将缓冲区内的也传给子进程,那么下一次printf的时候就会输出两颗星。
下面手画一个图描述一下,略丑,勿喷。

下面一个题:
今天的重头戏
代码如下:

int main(int argc,char *argv[])
{
	fork();
	fork()&&fork()||fork();
	//A&&B||C
	//如A是假,B跳过;A为真,B执行,(A&&B)为真
	fork();
	
}

首先要知道c语言的短路现象,(java就不是短路现象,&&和||两边的操作数无论如何都会进行计算)
A&&B||C
如A是假,B跳过;A为真,B执行,(A&&B)为真
同时知道fork()的返回值
1)在父进程中,fork返回新创建子进程的进程ID;
2)在子进程中,fork返回0;
3)如果出现错误,fork返回一个负值;
网上有很多解释,但我没有看,这里给出我自己的解法:

首先,把5个fork()函数分别标记为①②③④⑤,用来相互区别,然后直接进行算结果
注意这个代码的运行结果有20个*,而题目讲的是产生的新进程的话,是19个进程,结果如下
在这里插入图片描述
下面依然是手画的图,略丑,勿喷;

在这里插入图片描述
图只画了下面的那一部分,上面的那部分也一样,最后算新进程的一共有19个即,10*2-1;
至于问为啥不花全,别问,问就是懒。重度懒癌患者加巨忙。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值