免费注册 查看新帖 |

Chinaunix

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

[学习] 见鬼的printf函数!!! [复制链接]

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 09:56:11操作系统版块每日发帖之星
日期:2016-06-12 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-11-24 02:08 |只看该作者 |倒序浏览
本帖最后由 miniboy 于 2014-11-24 02:11 编辑

如图所示,两个printf函数相临紧挨一起; 一个执行,另一个不执行;
图片左边是代码,右边是GCC后执行结果。
第一个printf打印字符串执行完后,
第二个printf("==========Flag==========\n")  居然不是同步有结果输出。呈现有时执行有时不执行的效果。

何故?

(补充一下:花括号的位置和数量,都正确。第二个printf下就是右花括号,else  {} 的)

论坛徽章:
46
2015小元宵徽章
日期:2015-03-06 15:58:18羊年新春福章
日期:2015-04-14 10:37:422015年亚洲杯之阿曼
日期:2015-04-14 10:41:50NBA常规赛纪念章
日期:2015-05-04 22:32:03NBA季后赛大富翁
日期:2015-05-04 22:34:11菠菜明灯
日期:2015-05-04 22:35:49新奥尔良黄蜂
日期:2015-05-04 22:49:2315-16赛季CBA联赛之广夏
日期:2015-12-11 15:02:342015年亚洲杯之巴勒斯坦
日期:2015-03-04 19:56:562015年亚洲杯之阿联酋
日期:2015-03-04 11:19:04休斯顿火箭
日期:2015-03-02 16:32:11纽约尼克斯
日期:2015-03-02 16:09:04
2 [报告]
发表于 2014-11-24 10:01 |只看该作者
何谓不能同步,标准输出上是基于行缓冲的。

论坛徽章:
2
2016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之广夏
日期:2016-12-07 08:32:11
3 [报告]
发表于 2014-11-24 11:33 |只看该作者
行缓冲区1024B,加个\n刷新缓冲区才会输出,不然缓冲区满了才会输出

论坛徽章:
1
天蝎座
日期:2013-12-06 18:23:58
4 [报告]
发表于 2014-11-24 12:18 |只看该作者
回复 3# 剑魂箫心


    这是printf的特性撒,不然多次系统调用会浪费性能

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 09:56:11操作系统版块每日发帖之星
日期:2016-06-12 06:20:00
5 [报告]
发表于 2014-11-24 17:34 |只看该作者
回复 3# 剑魂箫心


    哦,我测试一下,谢谢。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP