fork之前的printf为什么打了两次

fork()前的printf打印两次的问题
这几天在看Linux应用编程, 测试了一下里面所讲的fork函数。 不是说子进程会从fork语句处开始运行吗? 为啥之前的printf内容还会被输出。 在网上找了一下,大概是这么回事:
———————————————————————————–
main()
{
int a;
int pid;
printf(“AAAAAAAA”); // 这里为什么会被print 2次
pid=fork();
if(pid==0){
printf(“ok”);}
else if(pid>;0){
printf(“is ok\n”);
}
printf(“BBBBBBB”);
}
—————————————————————————————
如果你将 printf(“AAAAAA”) 换成 printf(“AAAAAA\n”) 那么就是只打印一次了.
主要的区别是因为有了一个 \n 回车符号
这就跟Printf的缓冲机制有关了,printf某些内容时,操作系统仅仅是把该内容放到了
stdout的缓冲队列里了,并没有实际的写到屏幕上
但是,只要看到有 \n 则会立即刷新stdout,因此就马上能够打印了.
运行了printf(“AAAAAA”) 后, AAAAAA 仅仅被放到了缓冲里,再运行到fork时,缓冲里面
的 AAAAAA 被子进程继承了
因此在子进程度stdout缓冲里面就也有了 AAAAAA.
所以,你最终看到的会是 AAAAAA 被printf了2次!!!!
而运行 printf(“AAAAAA\n”)后, AAAAAA 被立即打印到了屏幕上,之后fork到的子进程里
的stdout缓冲里不会有 AAAAAA 内容
因此你看到的结果会是 AAAAAA 被printf了1次!!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 引用:CSDN jason314 一、fork入门知识 一个进程,包括代码、数据和分配给进程的资源。fork()函...
    _Nullptr阅读 20,910评论 1 19
  • linux资料总章2.1 1.0写的不好抱歉 但是2.0已经改了很多 但是错误还是无法避免 以后资料会慢慢更新 大...
    数据革命阅读 12,239评论 2 33
  • 亲爱的小伙伴们,大家晚上好!从今天开始,我将为大家解读《非暴力沟通》 《非暴力沟通》的作者——马歇尔 · 卢森堡是...
    百炼生阅读 934评论 0 0
  • 从在大门口换鞋地方羞愧的蹲到到地下那一刻起,就不知道还该怎么样面对你!我禽兽一样的行为,居然倒行逆施在自己视之为爱...
    慈伟_M认真阅读 337评论 0 0