免费注册 查看新帖 |

Chinaunix

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

printf 与sleep一起运行时的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-03-04 19:48 |只看该作者 |正序浏览
代码如下:
#include <stdio.h>

int main (int argc,char **argv)
{
              while (1)
             {
                      printf ("Hello Linux \n");
                      sleep(1);
             }
               return 0;
}
输出结果:每隔1秒输出Hello Linux
将上面代码改成:
#include <stdio.h>

int main (int argc,char **argv)
{
              while (1)
             {
                      printf ("Hello Linux ");
                      sleep(1);
             }
               return 0;
}
即将printf中的\n去掉,此程序运行时不会按照一秒钟输出一次Hello Linux.
大概过了几十秒输出一串Hello Linux.
不知这是哪个函数造成这种现象?是什么机制?谢谢!

论坛徽章:
36
CU大牛徽章
日期:2013-09-18 15:24:20NBA常规赛纪念章
日期:2015-05-04 22:32:03牛市纪念徽章
日期:2015-07-24 12:48:5515-16赛季CBA联赛之辽宁
日期:2016-03-30 09:26:4715-16赛季CBA联赛之北控
日期:2016-03-30 11:26:2315-16赛季CBA联赛之广夏
日期:2016-05-20 15:46:5715-16赛季CBA联赛之吉林
日期:2016-05-24 11:38:0615-16赛季CBA联赛之青岛
日期:2016-05-30 13:41:3215-16赛季CBA联赛之同曦
日期:2016-06-23 16:41:052015年亚洲杯之巴林
日期:2015-02-03 15:05:04CU大牛徽章
日期:2013-09-18 15:24:52CU十二周年纪念徽章
日期:2013-10-24 15:46:53
14 [报告]
发表于 2013-02-20 14:17 |只看该作者
学了半年的C语言,至今我还不知道printf()是如何工作的

论坛徽章:
0
13 [报告]
发表于 2013-02-20 08:54 |只看该作者
回复 11# safedead


    解释的很到位

论坛徽章:
0
12 [报告]
发表于 2008-03-06 11:43 |只看该作者
原帖由 safedead 于 2008-3-6 10:54 发表
行缓冲系统
顾名思义,就是按照“行”来缓冲的
只有缓冲区内容构成“行”或者缓冲区满
才会输出

什么是构成“行”的基本要素?你的程序里面哪个位置会产生相应要素?


建议safedead当大学老师去。呵呵
嗯,说的很清楚了。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
11 [报告]
发表于 2008-03-06 10:54 |只看该作者
行缓冲系统
顾名思义,就是按照“行”来缓冲的
只有缓冲区内容构成“行”或者缓冲区满
才会输出

什么是构成“行”的基本要素?你的程序里面哪个位置会产生相应要素?

论坛徽章:
0
10 [报告]
发表于 2008-03-06 10:08 |只看该作者
原帖由 hb12112 于 2008-3-5 18:44 发表
是这样子的呵。看的是GNU/Linux这本书呵。
没有介绍的很详细,是不是把缓冲区写满了才输出的。


明白了就好。

论坛徽章:
0
9 [报告]
发表于 2008-03-05 18:44 |只看该作者
是这样子的呵。看的是GNU/Linux这本书呵。
没有介绍的很详细,是不是把缓冲区写满了才输出的。

论坛徽章:
0
8 [报告]
发表于 2008-03-05 09:02 |只看该作者
原帖由 yangtou 于 2008-3-4 23:41 发表
不正常和正常有什么区别?


他可能是看的printf出来的很快就觉得是正常的

论坛徽章:
0
7 [报告]
发表于 2008-03-04 23:55 |只看该作者
跟sleep有关系吗

论坛徽章:
0
6 [报告]
发表于 2008-03-04 23:41 |只看该作者

回复 #5 hb12112 的帖子

不正常和正常有什么区别?
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP