格式化输出函数:printf 那些事 (C语言)
printf函数提供格式化输出转换
函数包含在头文件 <stdio.h> 中
#include <stdio.h>
......
函数的原型在头文件的声明为
_CRTIMP __cdecl __MINGW_NOTHROW int printf (const char *, ...);
第一个参数 const char * 来指明输出的格式 , 按照格式对输出进行转换, 并写到标准输出流中(stdin),后面的三个点 . . . 表示此处的参数是可变参数,这样可以满足不同的输出需求
如果打印输出成功函数返回打印的字节数(函数返回值为 int 类型), 如果出错则返回一个负值
1 #include <stdio.h>
2
3 int main()
4 {
5 int i = printf("你好\n");
6 printf("%d\n", i);
7 return 0;
8 }
输出
你好
5
成功输出 你好 并且返回打印的字符个数 5 (一个汉字的编码占2个字节 * 2 + '\n'一个字节 = 5)
格式串由两种类型对象组成:
----- 普通字符(将被复制到输出流中)
----- 转换说明(分别决定下一个后续参数的转换和打印), 每个转换说明均以 % 开头, 以转换字符结束, 在%与转换字符之间可以一次包括下列内容
- 标志
- 指定被转换的参数在其字段内左对齐
#include <stdio.h> int main()
{
printf("%20s\n", "hello world\n");
printf("%-20s\n", "hello world\n");
return ;
}
输出
hello world hello world
+ 只定在输出的数前面加上正负号
#include <stdio.h> int main()
{
int i = printf("%20s\n", "hello world\n");
printf("%d\n", i);
printf("%+d\n", i);
printf("%+d\n", -i);
return ;
}
输出
hello world 21
+21
-21
空格 如果第一个字符不是正负号, 则在它的前面加上空格
#include <stdio.h> int main()
{
int i = printf("%20s\n", "hello world\n");
printf("%d\n", i);
printf("%+d\n", i);
printf("%+d\n", -i);
printf("%+ d\n", -i);
printf("% d\n", i);
return ;
}
输出
hello world 21
+21
-21
-21
21
0 对于数制转换, 当输出长度小于字段宽度时, 在前面添加 0 作为填充
#include <stdio.h> int main()
{
int i = printf("%20s\n", "hello world\n");
printf("%06d\n", i);
return ;
}
输出
hello world 000021
# 指定另一种输出格式。 如果为 o 则第一个数字为0(表示八进制), 如果为 x 或 X , 则指定在输出的非0值前加 0x 或 0X (表示十六进制)
#include <stdio.h> int main()
{
int i = printf("你好!!!\n");
printf("%#o\n", i);
return ;
}
输出
你好!!!
010
共 8 个字节, 八进制是 010
#include <stdio.h> int main()
{
int i = printf("!!!!!!你好!!!!!\n");
printf("%#x\n", i);
printf("%#X\n", i);
return ;
}
输出
!!!!!!你好!!!!!
0x10
0X10
共 16 个字节, 十六进制是 0x10
- 一个数值, 用于指定最小字段宽度
#include <stdio.h> int main()
{
printf("%d\n", );
printf("%d\n", );
printf("%d\n", );
printf("%6d\n", );
printf("%6d\n", );
printf("%6d\n", );
return ;
}
输出
8
9
10
8
9
10
当然这里默认是右对齐的
- 点号,用于分隔字段宽度和精度
- 表示精度的数
#include <stdio.h>
#define PI 3.1415926535897932384626433832795028841971693993751058209
int main()
{
printf("%30.20f\n", PI);
}
输出
3.14159265358979310000
可以看出双精度浮点型可以精确到小数点后 16 位左右
------------------- 宽度和精度中任何一个或者两个都可以用 * 代替, 通过转换下一个参数计算得到(下一个参数必须为 int 类型)
#include <stdio.h>
#define PI 3.1415926535897932384626433832795028841971693993751058209
int main()
{
int a = , b = ;
printf("%*.*f\n", a, b, PI);
}
当然结果和上面一样
- 长度修饰符 h , l 或 L 。
h:将相应的参数按照 short 或 unsigned short 类型输出
l:将相应的参数按照 long 或 unsigned long 类型输出
L:将相应的参数按照 long double 类型输出
printf 函数的转换字符(以 % 开头, 如果 % 后面的字符不是转换字符, 则它行为没有定义)
转换字符 | 参数类型, 转换结果 |
d, i | int, 有符号十进制表示 |
o | unsigned int, 无符号八进制表示(无前导0) |
x, X | unsigned int, 无符号十六进制表示(无前导0x和0X)。如果是0x, 则使用abcdef, 如果是0X, 则使用ABCDEF |
u | int, 无符号十进制表示 |
c | int, 转换为unsigned char类型后为一个字符 |
s | char *, 打印字符串中的字符, 知道遇到 '\0' 或者已经打印了有精度指定的字符数 |
f | double, 形式为 [-]mmm.ddd 的十进制表示, 其中, d的数目由精度确定, 默认精度为6, 精度为0时不输出小数点 |
e, E | double, 形式为 [-]m.dddddd e (+/-) xx 或 [-]m.dddddd E (+/-) xx 的十六进制表示, d的数目由精度确定, 默认为6, 精度为0时不输出小数点 |
g, G | double, 当指数小于 -4 或大于等于精度时, 采用 %e 或 %E 的格式, 否则采用 %f 的格式, 尾部的0与小数点不打印 |
p | void *, 打印指针值(具体表示方式与实现有关) |
n | int *, 到目前为止, 此printf调用输出的字符的数目将被写入到相应参数中, 不进行参数转换 |
% | 不进行参数转换, 打印一个符号 % |
最新文章
- POCO库——Foundation组件概述
- maven创建的Web工程,Eclipse 内 tomcat容器不识别的处理方法
- Erlang库 -- 有意思的库汇总
- 【BZOJ】【3007】拯救小云公主
- GPRS连接失败问题
- 一个ASP函数库
- 如何使用picasso 对Android图片下载缓存
- SSH框架的简单学习—Structs学习
- App开发所要注意的几个法务问题(转)
- iOS 播放GIf图, 动态效果
- CJOJ 1308 【HNOI 2002 】营业额统计 / CodeVS 1296 营业额统计(STL,二分)
- redis资料收集
- 数据结构——线性表——队列(queue)
- prometheus — 基于文件的服务发现
- java 幂等性(转)
- Shiro Remember me设置
- exec 动态脚本 里面的参数和sp_executesql (注意引号,否则容易异常)
- 2012年蓝桥杯省赛A组c++第2题(暴力求解古堡算式)
- spark:ML和MLlib的区别
- C#DateTime好用但不常用的用法