printf原理.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
printf()函数 作用:向终端输出若干个任意类型的数据(putchar 只能输出字符,而且只能是一个字符,而printf可    以输出多个数据,且为任意类型) 一、 printf()的一般格式 printf(格式控制,输出列表);  例: int i = 3; double f = 4.56; printf(i = %d, f = %f\n, i,f); printf()是函数,“格式控制”和“输出列表”是其参数。可以表示为:printf(参数1,                     参数2,参数3,....,参数n); 其中“参数1”表示“格式控制”;其余参数表示“输出 列表。 二、格式字符 1、d格式符:按十进制格式输出。 %d 输出数字长度为变量数值的实际长度 %md m指定输出数据的宽度。当数据本身的实际宽度,,,,于m时,则数据左端补空格;若大于m,则按数据的实际位数输出。 %ld,%mld l(,,,,写字母L)表示输出“长整型”数据 %0md,%0mld 0(数字0)表示位数不足m时补0 注:%后面的m(位数控制)、0(位数不足补0)对于其他格式符也适用。 例:(□表示空格) int i = 123; long j = 123456; printf(%d□5d□05d,□ld□8ld□08ld,i,i,i,j,j,j); 123□□□123□00123,□123456□□□123456 2、o(字母)格式符:按八进制格式输出整数。(不会出现负数格式) 3、x格式符:按十六进制格式输出整数。(不会出现负数格式) 4、u格式符:以十进制数形式输出unsigned的整数。 [例3.2] main() { unsigned int a = 65535; int b = -2; printf(a=%d,%o,%x,%u\n,a,a,a,a); printf(a=%d,%o,%x,%u\n,b,b,b,b); } a=-1,177777,ffff,65535 b=-2,177776,fffe,65534 5、c格式符:用来输出一个字符。一个整数,其值在0~255之间时也可以以字符的格式输出  例: char c; printf(%c,c); 一个整数,若其值在0~255范围内,也可以用字符形式输出,在输出前,将该整数转换为对应的ASCII字符。反之,一个字符数据也可以用整数形式输出。 [例3.3] main() { char c = a; int i = 97; printf(%c,%d\n,c,c); printf(%c,%d\n,i,i); } 运行结果为: a,97 a,97 6、s格式符:用来输出一个字符串。 %s 用来输出一个字符串,不含双引号. 例:printf(%s,CHINA); %ms m指定宽度(字符串长度,,,,于m时左补空格,大于时按实际宽度输出) %-ms 左对齐,不足m时右补空格 %m.ns 输出占m列,只取字符串中左端n个字符.这n各字符输出在m列的右侧,左补空格. %-m.ns 同上,右补空格 7、f格式符:按实数格式输出。 %f 整数部分全部显示出来,,,,,数部分显示6位.但并不是显示的所有数字都是有效数字 %m.nf 指定数据的宽度共为m列,其中有n位,,,,数.如果数值长度,,,,于m,则左侧补空格。 %-m.nf 与%m.f类似,只是应在右侧补空格 [例3.5] main() { float x, y; x = 111111.111; y = 222222.222; printf(%f, x+y); } 程序输出: 333333.328152(实数运算中误差不可避免) [例3.6] main() { double x,y; double x2,y2; x = 1111111111111.111111111;y = 2222222222222.222222222; x2= 1111111111111.111; y2= 2222222222222.222; pr

文档评论(0)

dd545454 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档