免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 2802 | 回复: 14
打印 上一主题 下一主题

fork的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-08-18 16:07 |只看该作者 |倒序浏览
  1. #include <stdio.h>
  2. #include <sys/types.h>
  3. #include <unistd.h>

  4. int main(void)
  5. {
  6.         printf("one");
  7.         fork();
  8.         printf("two\n");

  9.         return 0;
  10. }
复制代码
结果是:
onetwo
onetwo

为什么printf("one")也执行了两遍?

论坛徽章:
0
2 [报告]
发表于 2010-08-18 16:15 |只看该作者
没有人知道?

论坛徽章:
1
午马
日期:2013-08-23 23:39:47
3 [报告]
发表于 2010-08-18 16:17 |只看该作者
printf("one");
printf("two\n");

你是来没事找事的吧

论坛徽章:
0
4 [报告]
发表于 2010-08-18 16:17 |只看该作者
本帖最后由 davelv 于 2010-08-18 19:31 编辑

可能是IO缓冲的问题,我把第一个也加上换行符号结果就成了这样
[dave@dave ~]$ ./a.out
one
two
我再运行两下就恢复正常了
[dave@dave ~]$ ./a.out
one
two
two

论坛徽章:
0
5 [报告]
发表于 2010-08-18 16:19 |只看该作者
printf("one");
printf("two\n");

你是来没事找事的吧
phy0077 发表于 2010-08-18 16:17



    没有明白的意思

论坛徽章:
0
6 [报告]
发表于 2010-08-18 16:19 |只看该作者
回复 1# rainfly100


    你把第一个printf改成
    fprintf(stderr,"one");
    试试

论坛徽章:
0
7 [报告]
发表于 2010-08-18 16:21 |只看该作者
可能是IO缓冲的问题,我把第一个也加上换行符号结果就成了这样
[dave@dave ~]$ ./a.out
one
two
davelv 发表于 2010-08-18 16:17



    加了换行符结果是:
one
two
two

按我对fork的理解这个才是正确的,就是不明白不加换行符,结果跟我想的不一样,我觉得应该是
onetwo
two

论坛徽章:
0
8 [报告]
发表于 2010-08-18 16:23 |只看该作者
回复 7# rainfly100


    子进程继承了父进程的很多东西,包括还在缓冲区中的那个字符串“one”

论坛徽章:
0
9 [报告]
发表于 2010-08-18 16:24 |只看该作者
我觉得可能是第一个printf把数据放入IO缓冲,而后被子进程继承了。
可以在第一个printf的后面加入fflush(stdout);来强制刷新缓存。
或者按照6楼所说的输出的stderr里面,stderr是不缓冲的。

论坛徽章:
0
10 [报告]
发表于 2010-08-18 16:25 |只看该作者
回复  rainfly100


    子进程继承了父进程的很多东西,包括还在缓冲区中的那个字符串“one”
chong232 发表于 2010-08-18 16:23



    哦,谢谢,那就是说没有加换行符,缓冲区就还有数据吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP