第一部分 函数概念
printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出
信息。在编写程序时经常会用到此函数。函数的原型为:
int printf(const char *format, ...);
函数返回值为整型。若成功则返回输出的字符数,输出出错则返回负值。
printf()函数的调用格式为:
printf("<格式化字符串>", <参量表>);
其中格式化
字符串包括两部分内容: 一部分是正常字符, 这些字符将按原
样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,
用来确定输出内容格式。
参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出
参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想
不到的错误
第二部分 规定符
%d 十进制有符号整数
%u 十进制
无符号整数
%f 浮点数
%s 字符串
%c 单个
字符
%p
指针的值
%e 指数形式的浮点数
%x, %X 无符号以
十六进制表示的整数
%o 无符号以
八进制表示的整数
%g 把输出的值按照%e或者%f类型中输出长度较小的方式输出
%p 输出地址符
%lu 32位无符号整数
%llu 64位无符号整数
第三部分 说明
(1). 可以在"%"和字母之间插进数字表示最大
场宽。
例如: %3d 表示输出3位整型数, 不够3位右对齐。
%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,
小数点占一位, 不够9位右对齐。
%8s 表示输出8个
字符的字符串, 不够8个字符右对齐。
如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。
但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;
若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。
另外, 若想在输出值前加一些0, 就应在场宽项前加个0。
(注,实测在VS2013中,char p = 0xF7; printf("%04x",p));是输出FFF7,也即,当补0的时候,实际上是
根据输出的最高位是1还是0进行补充,如果是1,则补F,如果是0,则补0)
例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度
为4位。
小数点前的数字代表最小宽度。
例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则
第9个字符以后的内容将被删除。
(2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。
例如: %ld 表示输出long整数
%lf 表示输出
double浮点数
(3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可
说明输出为左对齐, 否则为右对齐。
例如: %-7d 表示输出7位整数左对齐
%-10s 表示输出10个
字符左对齐
第四部分 特殊的作用
\n 换行
\f 清屏并换页
\r 回车
\t Tab符
\xhh 表示一个ASCII码用16进表示,
其中hh是1到2个16进制数
第四部分 输出字符和数据类型对照表
字符 | 对应数据类型 | 含义 |
d / i | int | 接受整数值并将它表示为有符号的十进制整数,i是老式写法 |
o | unsigned int | 无符号8进制整数(不输出前缀0) |
u
| unsigned int | 无符号10进制整数 |
x / X
| unsigned int | 无符号16进制整数,x对应的是abcdef,X对应的是ABCDEF(不输出前缀0x) |
f(lf)
| float(double) | 单精度浮点数用f,双精度浮点数用lf(尤其scanf不能混用) |
e / E
| double | 科学计数法表示的数,此处"e"的大小写代表在输出时用的“e”的大小写 |
g / G
| double | 使用以上两种中最短的形式,大小写的使用同%e和%E |
c
| char | 字符型。可以把输入的数字按照ASCII码相应转换为对应的字符 |
s / S
| char * / wchar_t * | 字符串。输出字符串中的字符直至字符串中的空字符(字符串以'\0‘结尾,这个'\0'即空字符) |
p
| void * | 以16进制形式输出指针 |
n | int * | 到此字符之前为止,一共输出的字符个数,不输出文本 |
%
| 无输入 |
不进行转换,输出字符‘%’(百分号)本身
|
m | 无 | 打印errno值对应的出错内容,(例: printf("%m\n"); ) |
注:%g、%G在小数点位数四位或指数大于等于精度时用%e、%E,否则用%f。