标准IO缓冲

一、问题描述:

终端无输出结果。

二、分析问题

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

你可能感兴趣的:(C++,c,PHP,.net,bbs)