C中的%d,%o,%f,%e,%x的区别

随声附和 提交于 2019-12-25 13:45:37

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

C中的格式字符有d,o,x,u,c,s,f,e,g等,之前有看到其中某些可以大写(待确定)。 
如:

%d整型输出,%ld长整型输出,

%o以八进制数形式输出整数,

%x以十六进制数形式输出整数,

%u以十进制数输出unsigned型数据(无符号数)。

%c用来输出一个字符,

%s用来输出一个字符串,

%f用来输出实数,以小数形式输出,

%e以指数形式输出实数,

%g根据大小自动选f格式或e格式,且不输出无意义的

 

c语言中以16进制输出时%0x和%x有什么区别?


标准C语言库函数fprintf/printf格式字符串的转换说明形式是这样的:

%[标志][最小输出宽度][.精度][长度修正符]类型
方括号括起来为option项目。

当[标志]是0或多个标志字符,可以是任意顺序,常用有以下几个:
 -   左对齐,缺省是右对齐。
 + 带符号的值前面总是有个符号,也就是正数前面有+号,负数前面有-号。
 0  输出值的宽度小于最小宽度的话,用0填充,缺省是用空格填充。

0也是是一个标志字符,意思就是用0填充
 


特殊情况:C语言%p的含义:

格式控制符“%p”中的p是pointer(指针)的缩写。指针的值是语言实现(编译程序)相关的,但几乎所有实现中,指针的值都是一个表示地址空间中某个存储器单元的整数。printf函数族中对于%p一般以十六进制整数方式输出指针的值,附加前缀0x。
示例:
int i = 1;
printf("%p",&i);
相当于
int i = 1;
printf("0x%x",&i);
对于32位的指针,输出一般会是类似0xf0001234之类的结果。
%p存在的理由除了附加前缀输出的便利性以外,如LS所说,指针的大小是不确定的,由实现决定。根据地址空间的大小,一般有16位、32位、64位的指针。尽管目前32位平台上的指针一般全是32位的,但旧的一些平台上可能有多种长度的指针(例如非标准的near、far、huge修饰的pointer)混用,无法用%x、%lx、%hx、%llx(对应int、long、short、long long)中的任意一种保证能输出所有类型的指针。

 

 

scanf(控制字符,地址列表) ;


格式字符的含义同printf函数,地址列表是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址。如scanf("%d%c%s",&a,&b,str);

注意控制字符之间的格开字符,一般数据之间的分隔为:空格,tab,和回车;如获取的为字符时,空格和tab均可当为字符给自动录入。


 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!