printf函数详细讲解
(1)简介:
printf函数是c语言当中非常重要的格式化输出函数
其函数原型为:int printf(const char *format, ...);
其函数返回值:打印出的字符格式
其调用格式为:printf("<格式化字符串>", <参量表>);
(2)转换说明:
转换格式为:%[标志][宽度][.精度][类型长度]类型
除了最后的类型之外都是可选的字段
标志 | 意义 |
- |
项目是左对齐的;也就是说,会把项目打印在字段的左侧开始处。示例:"%-20s" |
+ |
有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:"%+6.2f" |
(空格) |
带符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志;示例:"% 6.2f" |
# |
使用转换说明的可选形式。若为%o格式,则以0开始;若为%x或%X格式,则以0x或0X开始。对于所有的浮点形式,#保证了即使不跟任何数字,也打印一个小数点符号。对于%g和%G格式,它防止尾随0被删除;示例:"%#o" |
0 |
对于所有的数字格式,用前导0而不是用空格填充字段。如果出现-标志或者指定了精度(对于整数)则忽略该标志;示例:"%010d" |
修饰符 | 意义 |
digit(s) | 字段宽度的最小。如果该字段不能容纳要打印的数或者字符串,系统就会使用更宽的字段。示例:"%4d" |
.digit(s) | 精度,对于%e,%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导0来达到这个位数。只使用"."表示其后跟随一个零,所以%.f和%.0f相同;示例:"%5.2f"打印一个浮点数,他的字段宽度为5个字符,小数点后面有两位数字 |
修饰符 | 意义 |
h | 和整数转换说明符一起使用,表示一个short int或unsigned short int类型数值;示例:"%hu" "%hd" "%hx" |
hh | 和整数转换说明符一起使用,表示一个signed char或unsigned char类型数值;示例:"%hhu" "%hhd" "%hhx" |
j | 和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值;示例:"%jd" "%jX" |
l | 和整数转换说明符一起使用,表示一个long int或unsigned long int类型数值;示例:"%lu" "%ld" |
ll | 和整数转换说明符一起使用,表示一个long long int或unsigned long long int类型数值(c99);示例:"%llu" "%lld" |
L | 和浮点转换说明符一起使用,表示一个long double值;示例:"%Lf" "%Le" |
t | 和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差对应的类型)(c99);示例:"%td" |
z | 和整数转换说明符一起使用,表示一个size_t值(sizeof返回类型)(c99);示例:"%zd" |
I64 | 和整数转换说明符一起使用,表示一个_int64值 |
转换说明 | 输出 |
%a | 浮点数、十六进制数字和p-计数法(c99) |
%A | 浮点数、十六进制数字和P-计数法(c99) |
%c | 一个字符 |
%d | 有符号十进制整数 |
%e | 浮点数、e-记数法 |
%E | 浮点数、E-计数法 |
%f | 浮点数、十进制记数法 |
%g | 根据数值不同自动选择%f或%e。%e格式在指数小于-4或者大于精度时使用 |
%G | 根据数值不同自动选择%f或%E。%E格式在指数小于-4或者大于精度时使用 |
%i | 有符号十进制整数(与%d相同) |
%o | 有符号八进制整数 |
%p | 指针 |
%s | 字符串 |
%u | 无符号十进制整数 |
%x | 使用十六进制数0x的无符号十六进制整数 |
%X | 使用十六进制数字0X的无符号十六进制证书 |
%% | 打印一个百分号 |
(3)示例:
1 #include <stdio.h> 2 3 int main() { 4 const char * pString = "Hello World"; 5 const int nNumber = 1024; 6 const double dNumber = 3.141593; 7 // %d 示例 8 printf("*%d*\n", nNumber); //输出:*1024* 9 printf("*%6d*\n", nNumber); //输出:* 1024* 10 printf("*%6.5d*\n", nNumber); //输出:* 01024* 11 printf("*%-6.5d*\n", nNumber); //输出:*01024 * 12 printf("*%06d*\n", nNumber); //输出:*001024* 13 printf("*%+6d*\n", nNumber); //输出:* +1024* 14 15 // %f 示例 16 printf("*%f*\n", dNumber); //输出:*3.141593* 17 printf("*%10f*\n", dNumber); //输出:* 3.141593* 18 printf("*%10.2f*\n", dNumber); //输出:* 3.14* 19 printf("*%-10.2f*\n", dNumber); //输出:*3.14 * 20 printf("*%+10.2f*\n", dNumber); //输出:* +3.14* 21 printf("*%010.2f*\n", dNumber); //输出:*0000003.14* 22 23 // %s 示例 24 printf("*%s*\n", pString); //输出:*Hello World* 25 printf("*%20s*\n", pString); //输出:* Hello World* 26 printf("*%-20s*\n", pString); //输出:*Hello World * 27 printf("*%.10s*\n", pString); //输出:*Hello Worl* 28 return 0; 29 }
(4)浮点参数的转换:
有用于打印浮点类型double和long double的转换说明符,但没有用于float的说明符。原因是在K&R C中float值在被用于表达式中或者被用作参数之前,会被自动转换成double类型。一般情况下,ANSI C不会自动把float转换成double。不过,为了保护大量现有的假设float参数仍会自动被转换成double。因此,不过是K&R C还是ANSI C,都无需专门的转换说明符来显示float。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】博客园携手 AI 驱动开发工具商 Chat2DB 推出联合终身会员
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步