免费注册 查看新帖 |

Chinaunix

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

[C++] 请教两个问题(printf 和 sprintf) [复制链接]

论坛徽章:
5
戌狗
日期:2014-06-09 10:29:10酉鸡
日期:2014-12-01 16:05:27处女座
日期:2015-01-07 18:35:262015亚冠之水原三星
日期:2015-06-03 09:26:222015亚冠之布里斯班狮吼
日期:2015-06-15 10:53:54
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-09-28 20:22 |只看该作者 |倒序浏览
1、printf和4k的关系?
  1. #include <cstdlib>
  2. #include <cstdio>
  3. #include <string>
  4. #include <iostream>
  5. using namespace std;
  6. int main()
  7. {
  8.     printf("hello\n");
  9.     while(1);
  10.     return 0;
  11. }
复制代码
如上代码,假设生成的可执行程序名字为a.out。
在一个终端执行nohup ./a.out &,然后另起一个终端,tail -f nohup.out,会发现没有输出,当输出大小为4k时才会有,何解?

2.sprintf
  1. #include <cstdlib>
  2. #include <cstdio>
  3. #include <iostream>
  4. #include <string>

  5. using namespace std;
  6. int main()
  7. {
  8.     char sb[100];
  9.     sprintf(sb, "%89%87");
  10.     cout << sb << endl;
  11.     return 0;
  12. }
复制代码
如上程序,执行后输出为%87,求解。

提前谢过!

论坛徽章:
0
2 [报告]
发表于 2015-09-29 16:26 |只看该作者
第一个问题:因为标准输出到终端时默认行缓冲或无缓冲,重定向到硬盘之后,就变成了全缓冲。nohup将程序的stdout重定向到文件里了。

论坛徽章:
5
金牛座
日期:2015-07-03 13:32:00卯兔
日期:2015-07-03 13:32:17程序设计版块每日发帖之星
日期:2015-11-29 06:20:0015-16赛季CBA联赛之同曦
日期:2015-12-15 09:36:06CU十四周年纪念徽章
日期:2016-07-06 17:18:48
3 [报告]
发表于 2015-09-29 16:47 |只看该作者
第二个问题,printf/sprintf的%是格式参数吧,"%%89%%87"这样写就可以了。

论坛徽章:
5
戌狗
日期:2014-06-09 10:29:10酉鸡
日期:2014-12-01 16:05:27处女座
日期:2015-01-07 18:35:262015亚冠之水原三星
日期:2015-06-03 09:26:222015亚冠之布里斯班狮吼
日期:2015-06-15 10:53:54
4 [报告]
发表于 2015-09-29 17:32 |只看该作者
回复 2# jwj070524


    多谢。将标准输出重定向到硬盘后,自动触发全缓冲??而全缓冲的大小是4K??

    能不能麻烦推荐几篇类似资料,再次谢过!

论坛徽章:
5
戌狗
日期:2014-06-09 10:29:10酉鸡
日期:2014-12-01 16:05:27处女座
日期:2015-01-07 18:35:262015亚冠之水原三星
日期:2015-06-03 09:26:222015亚冠之布里斯班狮吼
日期:2015-06-15 10:53:54
5 [报告]
发表于 2015-09-29 17:48 |只看该作者
回复 3# seanking1987


    只是比较好奇"%89%87" 是怎么解析的?

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
6 [报告]
发表于 2015-09-29 18:05 |只看该作者
用正确的写法做正确的事。。
错误的写法何苦纠结

论坛徽章:
5
戌狗
日期:2014-06-09 10:29:10酉鸡
日期:2014-12-01 16:05:27处女座
日期:2015-01-07 18:35:262015亚冠之水原三星
日期:2015-06-03 09:26:222015亚冠之布里斯班狮吼
日期:2015-06-15 10:53:54
7 [报告]
发表于 2015-09-30 14:11 |只看该作者
知其然知其所以然,感兴趣而已,莫怪

论坛徽章:
0
8 [报告]
发表于 2015-09-30 16:48 |只看该作者
回复 5# kaede_1

Glibc. See filedoalloc.c:L111. Here we use stat() to test if the fd is a tty, and set the buffering mode accordingly. (This is called from fileops.c.) stdout initially has a null buffer, and it's allocated on the first use of the stream based on the characteristics of fd 1.

大意是glibc通过判断文件描述符是不是tty来决定缓冲的方式,是tty的话就采用行缓冲。

悲剧,没有权限发表URL。但是难不倒我,我把URL用base64转换了下

aHR0cDovL3N0YWNrb3ZlcmZsb3cuY29tL3F1ZXN0aW9ucy8xMzkzMjkzMi93aHktZG9lcy1zdGRvdXQtbmVlZC1leHBsaWNpdC1mbHVzaGluZy13aGVuLXJlZGlyZWN0ZWQtdG8tZmlsZQ==

论坛徽章:
0
9 [报告]
发表于 2015-10-01 11:03 |只看该作者
kaede_1 发表于 2015-09-30 14:11
知其然知其所以然,感兴趣而已,莫怪


感兴趣就去看 glibc 和 kernel 源代码,用gdb单步跟踪一下就很清楚了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP