免费注册 查看新帖 |

Chinaunix

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

关于fork和shell重定向问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-11-01 09:53 |只看该作者 |倒序浏览

  1. #include <stdio.h>
  2. main()
  3. {
  4.         printf("hello,pid is %d\n",getpid());
  5.         if(fork()==0)
  6.                 printf("world,pid is %d\n",getpid());
  7. }
复制代码

  1. $ gcc -o q1 q1.c
复制代码


程序很简单,父进程输出hello,pid is....,子进程输出world,pid is...不过在shell下把输出 定向到文件后就有问题了,又多输出了一行

  1. $ ./q1
  2. hello,pid is 4223
  3. world,pid is 4224
  4. $ ./q1 >1
  5. $ cat 1
  6. hello,pid is 4225
  7. world,pid is 4226
  8. hello,pid is 4225
复制代码

用管道也是这样的情况

  1. $ ./q1 | cat
  2. hello,pid is 4231
  3. world,pid is 4233
  4. hello,pid is 4231
复制代码


第三行不应该有的,不知道为什么会这样?

[ 本帖最后由 anttna 于 2006-11-1 09:54 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2006-11-01 10:21 |只看该作者
printf("hello,pid is %d\n",getpid());
fflush(stdout);
        if(fork()==0)

普通文件进行最大的缓冲,你的printf("hello,pid is %d\n",getpid());父子都没有完成。

论坛徽章:
0
3 [报告]
发表于 2006-11-01 11:29 |只看该作者
严重同意楼上的,不愧是梨花小蓓蕾2代

论坛徽章:
0
4 [报告]
发表于 2006-11-01 11:55 |只看该作者
前老斑竹有一篇帖子专门讲这个问题

论坛徽章:
0
5 [报告]
发表于 2006-11-01 15:10 |只看该作者
呵呵,明白了
因为进程在fork时,子进程也复制了父进程的缓冲区,所以会出现两次hello
第1,2行才是子进程输出的,第三行是父进程输出的

谢谢flw2指点

论坛徽章:
0
6 [报告]
发表于 2006-11-01 15:17 |只看该作者
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP