printf()函数详解
感谢博主的分享:
1.printf()简介
printf()是C语⾔标准库函数,⽤于将格式化后的字符串输出到标准输出。标准输出,即标准输出⽂件,对应终端的屏幕。printf()申明于头⽂件stdio.h。
函数原型:
int printf ( const char * format, ... );
1
返回值:
正确返回输出的字符总数,错误返回负值,与此同时,输⼊输出流错误标志将被置值,可由指⽰器ferror来检查输⼊输出流的错误标志。
调⽤格式:
printf()函数的调⽤格式为:printf("格式化字符串",输出表列)。
格式化字符串包含三种对象,分别为:
(1)字符串常量;
(2)格式控制字符串;
(3)转义字符。
字符串常量原样输出,在显⽰中起提⽰作⽤。输出表列中给出了各个输出项,要求格式控制字符串和各输出项在数量和类型上应该⼀⼀对应。其中格式控制字符串是以%开头的字符串,在%后⾯跟有各种格式控制符,以说明输出数据的类型、宽度、精度等。
注:本⽂的所有⽰例代码均在Linux环境下以g++ 4.4.6编译成64位程序的执⾏。
2.格式控制字符串详解
printf的格式控制字符串组成如下:
%[flags][width][.prec][length]type
1
分别为:
%[标志][最⼩宽度][.精度][类型长度]类型。
1
2.1类型(type)
⾸先说明类型,因为类型是格式控制字符串的重中之重,是必不可少的组成部分,其它的选项都是可选的。type⽤于规定输出数据的类型,含义如下:
字符对应数据类
型
含义⽰例
d/i int输出⼗进制有符号32bits整数,i是⽼式写法printf("%i",123);输出123
o unsigned int⽆符号8进制(octal)整数(不输出前缀0)printf("0%o",123);输出0173 u unsigned int⽆符号10进制整数printf("%u",123);输出123
x/X unsigned int ⽆符号16进制整数,x对应的是abcdef,X对应的是
ABCDEF(不输出前缀0x)
printf("0x%x 0x%X",123,123);输出0x7b 0x7B
f/lf float(double)单精度浮点数⽤f,双精度浮点数⽤lf(printf可混⽤,但
scanf不能混⽤)
printf("%.9f %.9lf",0.000000123,0.000000123);输出0.000000123
0.000000123。注意指定精度,否则printf默认精确到⼩数点后六位
F float(double)与f格式相同,只不过 infinity 和 nan 输出为⼤写形式。例如printf("%f %F %f %F\n",INFINITY,INFINITY,NAN,NAN);输出结果为inf INF nan NAN
e/E float(double)科学计数法,使⽤指数(Exponent)表⽰浮点数,此
处”e”的⼤⼩写代表在输出时“e”的⼤⼩写
printf("%e %E",0.000000123,0.000000123);输出1.230000e-07
1.230000E-07
g float(double)根据数值的长度,选择以最短的⽅式输出,%f或%e printf("%g %g",0.000000123,0.123);输出1.23e-07 0.123 G float(double)根据数值的长度,选择以最短的⽅式输出,%f或%E printf("%G %G",0.000000123,0.123);输出1.23E-07 0.123
c char 字符型。可以把输⼊的数字按照ASCII码相应转换为对应
的字符
printf("%c\n",64)输出A
s char*字符串。输出字符串中的字符直⾄字符串中的空字符(字
符串以空字符’\0‘结尾)
printf("%s","测试test");输出:测试test
S wchar_t*宽字符串。输出字符串中的字符直⾄字符串中的空字符
(宽字符串以两个空字符’\0‘结尾)
setlocale(LC_ALL,"zh_CN.UTF-8");
wchar_t wtest[]=L"测试Test";
printf("%S\n",wtest);
输出:测试test
p void*以16进制形式输出指针printf("%010p","lvlv");输出:0x004007e6
n int*什么也不输出。%n对应的参数是⼀个指向signed int的
指针,在此之前输出的字符数将存储到指针所指的位置
int num=0;
printf("lvlv%n",&num);
printf("num:%d",num);
输出:lvlvnum:4
%字符%输出字符‘%’(百分号)本⾝printf("%%");输出:% m⽆打印errno值对应的出错内容printf("%m\n");
a/A float(double)⼗六进制p计数法输出浮点数,a为⼩写,A为⼤写printf("%a %A",15.15,15.15);输出:0x1.e4ccccccccccdp+3 0X1.E4CCCCCCCCCCDP+3
字符对应数据类
型
含义⽰例
注意:
(1)使⽤printf输出宽字符时,需要使⽤setlocale指定本地化信息并同时指明当前代码的编码⽅式。除了使⽤%S,还可以使⽤%ls。 (2)%a和%A是C99引⼊的格式化类型,采⽤⼗六进制p计数法输出
浮点数。p计数法类似E科学计数法,但不同。数以0x开头,然后是16进制浮点数部分,接着是p后⾯是以 2为底的阶码。以上⾯输出的15.15为例,推算输出结果。15.15转换成⼆进制为1111.00 1001 1001 1001 1001 ...,因为⼆进制表⽰数值的离散特点,计算机对于⼩数有时是不能精确表⽰的,⽐如0.5可以精确表⽰为0.120.12,⽽0.15却不能精确表⽰。将15.15对应的⼆进制右移三位,为1.1110 0100 1100 1100 1100 ...转换对应的⼗六进制就是
0x1.e4ccccccccccd,注意舍⼊时向⾼位进了1位。由于右移三位,所以⼆进制阶码就是3。最后的结果就是0x1.e4ccccccccccdp+3。
(3)格式控制字符串除了指明输出的数据类型,还可以包含⼀些其它的可选的格式说明,依序有 flags, width, .precision and length。下⾯⼀⼀讲解。
2.2标志(flags)
flags规定输出样式,取值和含义如下:
字符名称说明
-减号结果左对齐,右边填空格。默认是右对齐,左边填空格。
+加号输出符号(正号或负号)
space空格输出值为正时加上空格,为负时加上负号
#井号type是o、x、X时,增加前缀0、0x、0X。
type是a、A、e、E、f、g、G时,⼀定使⽤⼩数点。默认的,如果使⽤.0控制不输出⼩数部分,则不输出⼩数点。
type是g、G时,尾部的0保留。0数字零
将输出的前⾯补上0,直到占满指定列宽为⽌(不可以搭配使⽤“-”)
字符名称说明
⽰例:
printf("%5d\n",1000); //默认右对齐,左边补空格printf("%-5d\n",1000); //左对齐,右边补空格printf("%+d %+d\n",1000,-1000); //输出正负号
printf("% d % d\n",1000,-1000); //正号⽤空格替代,负号输出printf("%x %#x\n",1000,1000); //输出0x
printf("%.0f %#.0f\n",1000.0,1000.0)//当⼩数点后不输出值时依然输出⼩数点printf("%g %#g\n",1000.0,1000.0); //保留⼩数点后后的0printf("%05d\n",1000); //前⾯补0
输出结果为:
2.3输出最⼩宽度(width )
⽤⼗进制整数来表⽰输出的最少位数。若实际位数多于指定的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。width的可能取值如下:
width 描述⽰例
数值⼗进制整数
printf("%06d",1000);输出:001000*
星号。不显⽰指明输出最⼩宽度,⽽是以星号代替,在printf的输出参数列表中给出
printf("%0*d",6,1000);输出:001000
2.4精度(.precision )
精度格式符以“.”开头,后跟⼗进制整数。可取值如下:
.precision
描述.数值
⼗进制整数。
(1)对于整型(d,i,o,u,x,X),precision表⽰输出的最⼩的数字个数,不⾜补前导零,超过不截断。
(2)对于浮点型(a, A, e, E, f ),precision表⽰⼩数点后数值位数,默认为六位,不⾜补后置0,超过则截断。(3)对于类型说明符g或G,表⽰可输出的最⼤有效数字。
(4)对于字符串(s),precision表⽰最⼤可输出字符数,不⾜正常输出,超过则截断。precision不显⽰指定,则默认为0
.*
以星号代替数值,类似于width中的*,在输出参数列表中指定精度。
⽰例:
printf("%.8d\n",1000); //不⾜指定宽度补前导0,效果等同于%06d
printf("%.8f\n",1000.123456789);//超过精度,截断
printf("%.8f\n",1000.123456); //不⾜精度,补后置0
printf("%.8g\n",1000.123456); //最⼤有效数字为8位
printf("%.8s\n",“abcdefghij”); //超过指定长度截断
1
2
3
4
5
输出结果:
00001000
1000.12345679
1000.12345600
1000.1235
abcdefgh
1
2
3
4
5
注意,在对浮点数和整数截断时,存在四舍五⼊。
2.5类型长度(length)
类型长度指明待输出数据的长度。因为相同类型可以有不同的长度,⽐如整型有16bits的short int,32bits的int,也有64bits的long int,浮点型有32bits的单精度float和64bits的双精度double。为了指明同⼀类型的不同长度,于是乎,类型长度(length)应运⽽⽣,成为格式控制字符串的⼀部分。
因为Markdown表格不⽀持单元格合并,背景颜⾊等样式,所以直接引⽤的表格。
注意:黄⾊背景⾏标识的类型长度说明符和相应的数据类型是C99引⼊的。
⽰例代码:
printf("%hhd\n",'A'); //输出有符号char
printf("%hhu\n",'A'+128); //输出⽆符号char
printf("%hd\n",32767); //输出有符号短整型short int
printf("%hu\n",65535); //输出⽆符号短整型unsigned short int
printf("%ld\n",0x7fffffffffffffff); //输出有符号长整型long int
printf("%lu\n",0xffffffffffffffff); //输出有符号长整型unsigned long int
1
2
3
4
5
6
输出结果:
65
193
32767
65535
9223372036854775807
18446744073709551615
1
write的返回值2
3
4
5
6
注意:
long int到底是32bits还是64bits跟⽣成的程序是32bits还是64bits⼀⼀对应,如果使⽤g++编译程序的话,可通过-m32或-m64选项分别⽣成32bits和64bits的程序。因本⼈测试代码编译⽣成的是64bits的程序,所以long int也就是64btis。
3.转义字符
转义字符在字符串中会被⾃动转换为相应操作命令。printf()使⽤的常见转义字符如下:
转义字符意义
\a警报(响铃)符
\b回退符
\f换页符
\n换⾏符
\r回车符
\t横向制表符
\v纵向制表符
\\反斜杠
\”双引号
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论