一个有趣的题目—linux中的fork函数分析

首先要介绍一下printf的缓冲机制:printf输出内容时,并不是直接打印到屏幕上,而是先把内容放入到stdout的缓冲队列中。遇到\n或者刷新缓冲等情况时才会输出内容。

看一个小例子:

#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>

int main()
{
	printf("hhhh");
	//printf("hhhh\n");
	int pid=fork();
	if(pid==0)
	{
		printf("I am parent process!\n");
	}
	else if(pid>0)
	{
		printf("I am child process!\n");
	}
	else
	{
		printf("Errof!\n");
	}
	return 0;
}

fork()创建新进程时,会复制旧进程的一切内容,包括缓冲区的内容。因此,如果是printf("hhhh"),hhhh放入到缓冲区中,新进程缓冲区中也会有,结果新旧进程都会输出一次hhhh。而如果是printf("hhhh\n"),直接输出了,不存在于缓冲区中,新进程就不会输出hhhh。

 

下面看一个经常出现的笔试题目:

#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>

int main()
{
	int i=0;
	for(i=0;i<2;i++)
	{
		fork();
		printf("-\n");
	}
}

会输出几个-?

 

#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>

int main()
{
	int i=0;
	for(i=0;i<2;i++)
	{
		fork();
		printf("-");
	}
}

会输出几个-?

 

前一个输出6个,后一个输出8个。因为缓冲区的内容也被子进程复制了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值