参考博客:
c语言格式化符,C语言 格式化字符_啊湫湫湫丶的博客-CSDN博客
之前在查打印的时候,闹过%d来看float的笑话,抽空总结了一下:
Code
格式
%c
字符
%d
带符号整数
%i
带符号整数
%e
科学计数法, 使用小写"e"
%E
科学计数法, 使用大写"E"
%f
浮点数
%g
使用%e或%f中较短的一个
%G
使用%E或%f中较短的一个
%o
八进制
%s
一串字符
%u
无符号整数
%x
无符号十六进制数, 用小写字母
%X
无符号十六进制数, 用大写字母
%p
一个指针
%n
参数应该是一个指向一个整数的指针
指向的是字符数放置的位置
%%
一个'%'符号
一个位于一个%和格式化命令间的整数担当着一个最小字段宽度说明符,并且加上足够多的空格或0使输出足够长. 如果你想填充0,在最小字段宽度说明符前放置0. 你可以使用一个精度修饰符,它可以根据使用的格式代码而有不同的含义.
用%e, %E和 %f,精度修饰符让你指定想要的小数位数. 例如,
%12.6f
将会至少显示12位数字,并带有6位小数的浮点数.
用%g和 %G, 精度修饰符决定显示的有效数的位数最大值.
用%s,精度修饰符简单的表示一个最大的最大长度, 以补充句点前的最小字段长度.
所有的printf()的输出都是右对齐的,除非你在%符号后放置了负号. 例如,
%-12.4f
将会显示12位字符,4位小数位的浮点数并且左对齐. 你可以修改带字母l和h%d, %i, %o, %u和 %x 等类型说明符指定长型和短型数据类型 (例如 %hd 表示一个短整数). %e, %f和 %g 类型说明符,可以在它们前面放置l指出跟随的是一个double. %g, %f和 %e 类型说明符可以置于字符'#'前保证出现小数点, 即使没有小数位. 带%x类型说明符的'#'字符的使用, 表示显示十六进制数时应该带'0x'前缀. 带%o类型说明符的'#'字符的使用, 表示显示八进制数时应该带一个'0'前缀.