printf()、scanf()用法总结及其格式转换说明符
2012-05-06 08:07
281 查看
一、printf()
printf()的返回值为输出的字符个数,其格式控制如下列表所述:
表一、printf()格式转换说明符
表二、printf()格式转换修饰符
表三、printf()格式转换修饰标志
二、scanf()
scanf()的返回值为成功输入的项目个数,其控制格式如下列表所述
表四、scanf()格式转换说明符
表五、scanf()格式转换修饰符
对于scanf()除了%c以外,对每一个输入项忽略其前导空白字符(空格、制表艝、换行符)。从第一个非空白字符开始,直到遇到空白字符或达到宽度或遇到当前输入格式的非法字符时停止当前项输入,进入下一输入项
printf()的返回值为输出的字符个数,其格式控制如下列表所述:
表一、printf()格式转换说明符
转换说明 | 输出 |
%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 | 使用十六进制数字0f的无符号十六进制整数 |
%X | 使用十六进制数字0F的无符号十六进制整数 |
%% | 打印一个百分号 |
修饰 | 意义 |
标志 | 五种标志(-、+、空格、#、0)详细说明见表三。可以使用零个或者多个 例:“%-10d” |
digit 或* | 字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统就会使用更宽的字段。当为 * 号时,表示从参数中获取宽度。 例:“%4d”、printf("%*d", width, num) |
.digit或 .* | 精度。对于%e、%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数,如果必要,要使用前导0来达到这个位数。只使用“."和使用“.0”相同,所以%f与%.0f相同。当为 * 号时,表示从参数中获取精度。 例:“%5.2f“、printf("%5.*f", precision, num) |
h | 和整数转换说明符一起使用,表示一个short int 或 unsigned short int类型数值 例:”%hu“、”%hx“、”%6.4hd“ |
hh | 和整数转换说明符一起使用,表示一个char 或 unsigned char类型数值 例:”%hhu“、”%hhx“、”%6.4hhd“ |
j | 和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值 例:”%jd“、”%8jx“ |
l | 和整数转换说明符一起使用,表示一个long nt 或 unsigned long int类型数值 例:”%ld“、”%8lu“ |
ll | 和整数转换说明符一起使用,表示一个long long int 或 unsigned long long int类型数值(C99) 例:”%lld“、”%llu“ |
L | 和浮点转换说明符一起使用,表示一个long double值 例:”%Lf“、”%10.4Le“ |
t | 和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差相对应的类型)(C99) 例:”%td“、”%12ti“ |
z | 和整数转换说明符一起使用,表示一个size_t值(C99) 例:"%zd"、“%12zx” |
标志 | 意义 |
- | 项目是左对齐的 例:“%-4s” |
+ | 有符号的值若为正,则显示正号;若为负的,则显示负号 例:“%+6.2f” |
空格 | 有符号的值若为正,则显示空格代替正号;若为负的,则显示负号 例:“% 6.2f“ |
# | 使用转换说明的可选形式。若为%o格式,显示前导0;若为%x和%X格式,则显示前导0x和0X。对于所有浮点形式,#保证了即使不跟任何数字,也打印一 ac3c 个小数点字符。对于%g和%G格式,它防止尾随零被删除。 例:”%#o“、”%#x“、”%#8.0f“、”%+#10.3E“ |
0 | 对于所有的数字格式,用前导0来填充字段宽度,如果出现-标志或者指定了精度(对于整数)则忽略该标志 例:”%010d“、”%08。3f“ |
scanf()的返回值为成功输入的项目个数,其控制格式如下列表所述
表四、scanf()格式转换说明符
转换说明符 | 意义 |
%c | 把输入解释成一个字符 |
%d | 把输入解释成一个有符号十进制整数 |
%e、%f、 %g、%a | 把输入解释成一个浮点数(%a是C99标准) |
%E、%F、 %G、%A | 把输入解释成一个浮点数(%A是C99标准) |
%i | 把输入解释成一个有符号十进制整数 |
%o | 把输入解释成一个有符号八进制整数 |
%p | 把输入解释成一个指针(一个地址) |
%s | 把输入解释成一个字符串:输入的内容以第一个非空白字符作为开始, 至下一个空白字符之前的全部字符 |
%u | 把输入解释成一个无符号十进制整数 |
%x、%X | 把输入解释成一个无符号十六进制整数 |
修饰符 | 意义 |
* | 忽略一个输入项 例:scanf("%*d%d", &num), 当输入为 23 45时,23将被忽略,而读取45到num中 |
digit | 最大字段宽度。在达到最大字段宽度或遇到第一个空白字符时停止对输入项的读取 |
hh | 指示整数将会存储在char 或 unsigned char |
ll | 指示整数将会存储在 long long 或者 unsigned long long (C99) |
h、l、L | ”%hd“和”%hi“指示该值将会存储在一个short int中。”%ho“、”%hx“”%hu“指示该值将会存储在一个unsigned short int中。”%ld“和”%li“指示该值将存储在一个long中。”%lo“、”lx“、”lu“指示该值将会存储在一个unsigned long中。”%le“、”%lf“、”%lg“指示该值将会存储在double中。将L与e、f、g一起使用指示该值将会存储在long double中。如果没有这些修饰符,d、i、o、x指示int类型,e、f、g指示float类型 |
空格 | 只能修饰 %c , 忽略输入的前导空白字符 |
相关文章推荐
- printf与scanf的用法知识(C Primer Plus总结)
- 【总结】C语言中的scanf和printf函数易被忽略的部分
- scanf 和 printf的一般用法
- printf用法总结
- scanf和printf的另类用法
- Android中Context的总结及其用法
- C语言中printf(),scanf()用法
- C/C++日常学习总结(第一篇)const用法及printf的执行顺序
- scanf || printf 格式 小总结
- C语言中printf(),sprintf(),scanf(),sscanf(),fscanf()的用法和区别
- 总结linux下printf命令的用法
- C语言中printf(),sprintf(),scanf(),sscanf()的用法和区别
- Android中Context的总结及其用法
- 关于scanf函数和printf的总结
- 算法之美——开门人和关门人(printf,scanf用法)
- scanf sscanf,sscanf_s及其相关用法
- java学习总结(16.07.25)File类及其用法
- js字符串常用的方法总结,及其用法
- scanf和printf的用法详解
- C++ sscanf()用法总结