SunBo

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

一、问题描述:

终端无输出结果。

 

二、分析问题

1. 标准输出(stdout)是行缓冲模式。其何时会输出在于:printf里有'/n',fflush(stdout)或setbuf(stdout, NULL),缓冲区已满三种。在应用程序退出时(exit()),会ffush缓冲区。

2. 上述程序,如果将sleep(1) ->usleep(1000)会有输出,原因在于printf的缓冲区已满所以才会输出。

 

三、结论

由于sleep(1)等待时间稍长,printf缓冲区没有填满,所以终端没有输出。

 

另:可以通过如下程序测试printf的缓冲区大小:

当输出第一组数据时,立刻ctrl+c终止,拷贝数据到buf.txt文件,查看文件可知printf缓冲区大小。

 

参考资料:

《APUE》5.4节——缓冲

《关于 printf 和 缓冲区》http://hi.baidu.com/glasswm/blog/item/52b5dbc4ff06aec738db49a0.html

《关于流和缓冲区的理解以及一般标准输入问题的解决方法小结》http://bbs.chinaunix.net/viewthread.php?tid=588099

 

 

posted on 2010-10-12 17:30  SunBo  阅读(874)  评论(0编辑  收藏  举报