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"
printf函数是如何实现的
宽度,精度
修饰符意义
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
3int main() {
4const char * pString = "Hello World";
5const int    nNumber = 1024;
6const 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*
28return0;
29 }
(4)浮点参数的转换:
有⽤于打印浮点类型double和long double的转换说明符,但没有⽤于float的说明符。原因是在K&R C中float值在被⽤于表达式中或者被⽤作参数之前,会被⾃动转换成double类型。⼀般情况下,ANSI C不会⾃动把float转换成double。不过,为了保护⼤量现有的假设float参数仍会⾃动被转换成double。因此,不过是K&R C还是ANSI C,都⽆需专门的转换说明符来显⽰float。