免费注册 查看新帖 |

Chinaunix

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

[C] 为什么我这里apue中Race Conditions例子和运行结果不一样 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-01-20 11:17 |只看该作者 |倒序浏览
就是apue2里 8.9. Race Conditions中Program with a race condition的例子.


  1.               
  2. #include "apue.h"



  3. static void charatatime(char *);



  4. int

  5. main(void)

  6. {

  7.     pid_t   pid;



  8.     if ((pid = fork()) < 0) {

  9.         err_sys("fork error");

  10.     } else if (pid == 0) {

  11.         charatatime("output from child\n");

  12.     } else {

  13.         charatatime("output from parent\n");

  14.     }

  15.     exit(0);

  16. }



  17. static void

  18. charatatime(char *str)

  19. {

  20.     char    *ptr;

  21.     int     c;



  22.     setbuf(stdout, NULL);           /* set unbuffered */

  23.     for (ptr = str; (c = *ptr++) != 0; )

  24.         putc(c, stdout);

  25. }
复制代码

我用的是:
Linux debian 2.6.18.1l
gcc version 4.1.2 20061028 (prerelease) (Debian 4.1.1-19)
在gnome终端里运行后没有出现乱序,会不会是gnome终端无法设置
无缓冲输出?请大虾指教.

论坛徽章:
0
2 [报告]
发表于 2008-01-20 11:34 |只看该作者
可以在putc(c, stdout);加上睡眠一秒

论坛徽章:
0
3 [报告]
发表于 2008-01-20 11:57 |只看该作者
系统当前的负载量影响进程的调度

论坛徽章:
0
4 [报告]
发表于 2008-01-20 11:57 |只看该作者
谢谢,可以了,输出结果是
oouuttppuutt  ffrroomm  pcahrielndt

不过我想知道是不是因为系统比较快,进程时间还没有用完就输出完成了,才没有出现乱序

论坛徽章:
0
5 [报告]
发表于 2008-01-20 11:59 |只看该作者
APUE上已经说了输出可能并不相同

论坛徽章:
0
6 [报告]
发表于 2008-01-20 12:02 |只看该作者
谢谢各位,明白了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP