printf/scanf---格式化输出符号详细说明
2015-06-13 16:34
183 查看
一、 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的无符号十六进制整数
%% 打印一个百分号
二、 printf()符
修饰符 意 义
标志 五种标志 (-、+、空格、# 和0) 都将在表三中描述,可以使用零个或多个标志
digit(s) 字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统会使用更宽的字段。示例:“%4d”
.digit(s) 精度:对于%e、%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导零来达到这个位数。只使用“.”表示其后跟随一个零,所以%.f与%.0f相同。示例:“%5.2f”打印一个浮点数,他的字段宽度为5 个字符,小数点后有两个数字。
h 和整数转换说明符一起使用,表示一个short int 或者 unsigned short int 类型数值。
示例:“%hu”、“%hx”和“%6.4hd”
hh 和整数转换说明符一起使用,表示一个signed char 或者unsigned char类型数值。
示例:“%hhu”、“%hhx”和“%6.4hhd”
j 和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值。
示例:“%jd”和“%8jX”
l 和整数说明符一起使用,表示一个long int 或者unsigned long int 类型值。
示例:“%ld”和“%8lu”
ll 和整数说明符一起使用,表示一个long long int或 unsigned long long int 类型值 (C99)。
示例:“%lld”和“%8llu”
L 和浮点转换说明符一起使用,表示一个long double值。
示例:“%Lf”和“%10.4Le”
t 和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差相对应的类型) (C99)
示例:“%td”和“%12ti”
z 和整数转换说明符一起使用,表示一个size_t值(sizeof返回的类型) (C99)。
示例:“%zd”和“%12zx”
三、printf()标志
修饰符 意 义
- 项目是左对齐的,也就是说,会把项目打印在字段的左侧开始处。示例:“%-20s”
+ 有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:“%+6.2f”
(空格) 有符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志。示例:“% 6.2f”
# 使用转换说明的可选形式。若为%o格式,则以0开始;若为%x和%X格式,则以0x或0X开始,对于所有的浮点形式,#保证了即使不限任何数字,也打印一个小数点字符。对于%g和%G格式,它防止尾随零被删除。示例:“%#o”、“%#8.0f”和“%+#10.3E”
0 对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志。示例:“%010d”和“%08.3f”
四、scanf()转换说明符
转换说明符 意 义
%c 把输入解释成一个字符
%d 把输入解释成一个有符号十进制整数
%e,%f,%g, %a 把输入解释成一个浮点数 (%a是C99标准)
%E,%F,%G,%A 把输入解释成一个浮点数 (%A是C99标准)
%i 把输入解释成一个有符号十进制整数
%o 把输入解释成一个有符号八进制数
%p 把输入解释成一个指针(地址)
%s 把输入解释成一个字符串;输入的内容以一个非空白字符作为开始,并且包含知道下一个空白字符的全部字符
%u 把输入解释成一个无符号十进制整数
%x,%X 把输入解释成一个有符号十六进制整数
五、scanf()换修饰符
修饰符 意 义
* 滞后赋值。示例:“%*d”
digit(s) 最大字段宽度;在达到最大字段宽度或者遇到第一个空白字符时(不管哪一个先发生都一样)停止对输入项的读取。示例:“%10s”
hh 把整数读作signed char 或 unsigned char 。示例:“%hhd”“%hhu”
ll 把整数读作long long或者 unsigned long long (C99)。示例:“%lld”“%llu”
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(而非l)与e、f和g一起使用指示该值以long double类型存储。
如果没有这些修饰符,d、i、o和x指示int类型,而e、f和g指示float类型。
六、特别说明符
转换说明符 意 义
%I64 配合u,d等,可以输入输出64位整数.MSVC平台有效.如%I64u , %I64d. 注意大写
最后小结一下,一个字节的用%c,%hhu,%hhd等,两个字节用%hu,%hd等,四个字节用%d,%u等8个字节的用%lld,%llu等. 尽量不要用%I64d这样不兼容的格式.
转换说明 输 出
%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的无符号十六进制整数
%% 打印一个百分号
二、 printf()符
修饰符 意 义
标志 五种标志 (-、+、空格、# 和0) 都将在表三中描述,可以使用零个或多个标志
digit(s) 字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统会使用更宽的字段。示例:“%4d”
.digit(s) 精度:对于%e、%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导零来达到这个位数。只使用“.”表示其后跟随一个零,所以%.f与%.0f相同。示例:“%5.2f”打印一个浮点数,他的字段宽度为5 个字符,小数点后有两个数字。
h 和整数转换说明符一起使用,表示一个short int 或者 unsigned short int 类型数值。
示例:“%hu”、“%hx”和“%6.4hd”
hh 和整数转换说明符一起使用,表示一个signed char 或者unsigned char类型数值。
示例:“%hhu”、“%hhx”和“%6.4hhd”
j 和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值。
示例:“%jd”和“%8jX”
l 和整数说明符一起使用,表示一个long int 或者unsigned long int 类型值。
示例:“%ld”和“%8lu”
ll 和整数说明符一起使用,表示一个long long int或 unsigned long long int 类型值 (C99)。
示例:“%lld”和“%8llu”
L 和浮点转换说明符一起使用,表示一个long double值。
示例:“%Lf”和“%10.4Le”
t 和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差相对应的类型) (C99)
示例:“%td”和“%12ti”
z 和整数转换说明符一起使用,表示一个size_t值(sizeof返回的类型) (C99)。
示例:“%zd”和“%12zx”
三、printf()标志
修饰符 意 义
- 项目是左对齐的,也就是说,会把项目打印在字段的左侧开始处。示例:“%-20s”
+ 有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:“%+6.2f”
(空格) 有符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志。示例:“% 6.2f”
# 使用转换说明的可选形式。若为%o格式,则以0开始;若为%x和%X格式,则以0x或0X开始,对于所有的浮点形式,#保证了即使不限任何数字,也打印一个小数点字符。对于%g和%G格式,它防止尾随零被删除。示例:“%#o”、“%#8.0f”和“%+#10.3E”
0 对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志。示例:“%010d”和“%08.3f”
四、scanf()转换说明符
转换说明符 意 义
%c 把输入解释成一个字符
%d 把输入解释成一个有符号十进制整数
%e,%f,%g, %a 把输入解释成一个浮点数 (%a是C99标准)
%E,%F,%G,%A 把输入解释成一个浮点数 (%A是C99标准)
%i 把输入解释成一个有符号十进制整数
%o 把输入解释成一个有符号八进制数
%p 把输入解释成一个指针(地址)
%s 把输入解释成一个字符串;输入的内容以一个非空白字符作为开始,并且包含知道下一个空白字符的全部字符
%u 把输入解释成一个无符号十进制整数
%x,%X 把输入解释成一个有符号十六进制整数
五、scanf()换修饰符
修饰符 意 义
* 滞后赋值。示例:“%*d”
digit(s) 最大字段宽度;在达到最大字段宽度或者遇到第一个空白字符时(不管哪一个先发生都一样)停止对输入项的读取。示例:“%10s”
hh 把整数读作signed char 或 unsigned char 。示例:“%hhd”“%hhu”
ll 把整数读作long long或者 unsigned long long (C99)。示例:“%lld”“%llu”
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(而非l)与e、f和g一起使用指示该值以long double类型存储。
如果没有这些修饰符,d、i、o和x指示int类型,而e、f和g指示float类型。
六、特别说明符
转换说明符 意 义
%I64 配合u,d等,可以输入输出64位整数.MSVC平台有效.如%I64u , %I64d. 注意大写
最后小结一下,一个字节的用%c,%hhu,%hhd等,两个字节用%hu,%hd等,四个字节用%d,%u等8个字节的用%lld,%llu等. 尽量不要用%I64d这样不兼容的格式.
相关文章推荐
- eclipse 删除所有注释及空白行
- shareSDK
- Android studio
- 十三周项目一
- iOS程序进入后台后仍运行定时器
- DotNetBar for Windows Forms 12.2.0.7_冰河之刃重打包版原创发布-带官方示例程序版
- BZOJ 2654: tree( 二分 + MST )
- 面向对象程序设计
- 复杂数据的数据持久化
- gdb结合coredump定位崩溃进程
- 博客初心源于前端攻城狮
- printf中的%c,%d,%u........都分别代表输出的是什么类型的?
- 手机如何借用笔记本网络上网
- 24-m-Swap Nodes in Pairs
- iOS开发UI篇 -- 04011控制器切换方式之Modal介绍
- jdk自带的jvm监测程序
- XenApp_XenDesktop_7.6实战篇之九:SQL Server数据库服务器规划及部署
- OC-- UI基础笔记
- java: 复制文件最快方法
- 项目阶段总结