printf函数(格式输出函数)
printf函数,它的作用是向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据(printf可以输出多个数据,且为任意类型)。
1.printf函数的一般格式为
printf(格式控制,输出表列)
如:printf("%d,%c\n",i,c)
括弧内包括两部分:
(1)“格式控制”是用双撇号括起来的字符串,也称“转换控制字符串”,它包括两种信息:
①格式说明,由“%”和格式字符组成,如%d,%f等。它的作用是将输出的数据转换为指定的格式输出。格式说明总是由“%”字符开始的。
②普通字符,即需要原样输出的字符。例如上面printf函数中双撇号内的逗号、空格和换行符。
(2)“输出表列”是需要输出的一些数据,可以是表达式。下面是一个例子:
printr("%d %d",n,b);
格式说明 输出表列
printf(“a= %d b=%d",a,b);
格式说明 输出表列
在上面双撇号中的字符除了“%d”和“%d”以外,还有非格式说明的普通字符,它们按原样输出。如果a、b的值分别为3、4,则输出为
a=3 b=4
其中有下划线的字符是printf函数中的“格式控制”字符串中的普通字符按原样输出的结果。3和4是a和b的值(注意3和4无前导空格和尾随空格),其数字位数由a、b值而定。假如a=12 b=123,则输出结果为
a=12 b=123
由于printf是函数,因此,“格式控制”字符串和“输出表列”实际上都是函数的参数。 printf函数的一般形式可以表示为
printf(参数1,参数2,参数3……参数n)
printf函数的功能是将参数2~参数n按参数1给定的格式输出。
2. 格式字符
对不同类型的数据用不同的格式字符。常用的有以下几种格式字符:
- d格式符。用来输出十进制整数。有以下几种用法:
- %d,按整型数据的实际长度输出。
- %md,m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。如
printf("%4d,%4d",a,b);
若a=123,d=12345,则输出结果为 123,12345
- %ld,输出长整型数据。如
long a=135790; printf("%ld",a);
如果用%d输出,就会发生错误,因为整型数据的范围为-32768~32767。对long型数据应当用%ld格式输出。对长整型数据也可以指定字段宽度,如将上面 printf 函数中的“%Id”改为“%8ld”、则输出为:
135790
8列
一个int型数据可以用%d或%ld格式输出。
(2)o格式符,以八进制数形式输出整数。由于是将内存单元中的各位的值(或1)按八进制形式输出,因此输出的数值不带符号,即将符号位也一起作为八进制数的一部分输出。例如:
Int a=-1;
printí(" %d,%o”,a,a);
-1在内存单元中的存放形式(以补码形式存放)如下:
1 | 111111111111111 |
输出为
-1,177777
不会输出带负号的八进制整数对长整数(long型)可用”%lo”格式输出。同样可以指定字段宽度,如printf("%8o",a)输出为 177777
- x格式符,以十六进制数形式输出整数。同样不会出现负的十六进制数。例如:
Int a=-1;
printf("%x,%o,%d",a,a,a);
输出结果为
ffff,177777,-1
同样可以用“%lx”输出长整型数,也可以指定输出字段的宽度,如“%12x”。
(4)u格式符,用来输出unsigned型数据,即无符号数,以十进制形式输出。
一个有符号整数(int型)也可以用%u格式输出;反之,一个unsigned型数据也可以用%d格式输出。按相互赋值的规则处理。unsigned型数据也可用%o或%x格式输出。
例3 无符号数据的输出。
main()
{unsigned int a=65535;
Int b=-2;
printf(“a=%d,%o,%x,%u\n",a,a,a,a);
printf("b=%d,%o,%x,%u\n",b,b,b,b);
运行结果为;
a=-1,177777,ffff,65535
b=-2,177776,fffe,65534
- c格式符,用来输出一个字符。如:
char c='a';
printf(”%c",c);
输出字符a’,请注意:“%c”中的c是格式符,逗号右边的c是变量名,不要搞混。
一个整数,只要它的值在0~255范围内,也可以用字符形式输出,在输出前,系统会将该整数作为ASCII码转换成相应的字符;反之,一个字符数据也可以用整数形式输出。
例4字符数据的输出。
main()
{char c='a';
int i=97;
printf("%c,%d\n",c,c);
printf("%c,%d\n",i,i):
运行结果为:
a,97
a,97
也可以指定输出字数宽度,如果有 printf("%3c",c)
则输出:“一一a”,即c变量输出占3列,前2列补空格。
- s格式符,用来输出一个字符串。有几种用法:
①%s,例如:
printf("%s","CHINA")
输出“CHINA”字符串(不包括双引号)。
②%ms,输出的字符串占m列,如字符串本身长度大于m,则突破m的限制,将字符串全部输出。若串长小于m,则左补空格。
③%-ms,如果串长小于m,则在m列范围内,字符串向左靠,右补空格。
④%m,ns,输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
⑤%-m,ns,其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果 n>m,则m自动取n值,即保证n个字符正常输出。
例5字符串的输出。
main()
{
printf("%3s,%7.2s,%.4s,%-5.3s\n","CHINA" ,"CHINA","CHINA","CHINA");
}
输出如下:
CHINA, CH,CHIN,CHI
其中第3个输出项,格式说明为“%.4s”,即只指定了n,没指定m自动使m=n=4故占
4列。
(7)f格式符,用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:
①%f,不指定字段宽度,由系统自动指定,使整数部分全部如数输出,并输出6位小数。应当注意,并非全部数字都是有效数字。单精度实数的有效位数一般为7位。
例6 输出实数时的有效位数。
main()
{foat x,y;
x=111111.111;
y=222222.222;
printf("%f",x+y);
}
运行结果为333333.328125
显然,只有前7位数字是有效数字。千万不要以为凡是打印出来的数字都是准确的。双精度数也可用%f格式输出,它的有效位数一般为16位,给出小数6位。
例7 输出双精度数时的有效位数。
main()
{double x,y;
x=1111111111111.111111111;
y=2222222222222.222222222;
printf("%f" x+y);}
输出结果为3333333333333.333010
可以看到最后3位小数(超过16位)是无意义的。
②%m.nf指定输出的数据共占m列,其中有n位小数。如果数值长度小于m,则左端补空格。
③%-m.nf与%m.nf基本相同,只是使输出的数值向左端靠,右端补空格。
例8输出实数时指定小数位数。
main()
{floatf=123.456;
printf(”%f__%10f__%10.2f__%.2f__%-10.2f\n",f,f,f,f,f);}
输出结果如下:
123.455994__123.455994______123.46__123.46__123.46____(的值应为123.456,但输出为123.455994,这是由于实数在内存中的存储误差引起的。
(8)e格式符,以指数形式输出实数,可用以下形式:
①%e不指定输出数据所占的宽度和数字部分的小数位数,有的C编译系统自动指定给出6位小数,指数部分占5位(如e+002),其中“e”占1位,指数符号占1位,指数占3位。数值按规范化指数形式输出(即小数点前必须有而且只有1位非零数字)。例如
printf("%e",123.456);
输出:1.234560e+002。输出的实数共占13列宽度。(注:不同系统的规定略有不同)
6列 5列
②%m.ne 和%-m.ne,m、n和“-”字符含义与前相同。此处n指拟输出的数据的小数部分(又称尾数)的小数位数。若f-123.456则:
printf(”%e__%10e__%10.2e__%.2e__%-10.2e",ffff);
输出如下:
1.234560e+002__1234560+002___1.23e+002__1.23e+002__1.23e+002_
13列 13列 10列 9列 10列
第2个输出项按%10e输出,即只指定了m=10,未指定n,凡未指定n,自动使n=6,整个数据长13列,超过给定的10列,乃突破10 列的限制,按实际长度输出。第3个数据共占10列,小数部分占2列。第4个数据按“%.2e”格式输出,只指定n=2,未指定m,自动使 m等于数据应占的长度,今为9列。第5个数据应占10列,数值只有9列,由于是“%一10.2e”,数值向左靠,右补一个空格。(注:有的C系统的输出格式与此略有不同)
(9)g格式符,用来输出实数,它根据数值的大小,自动选f格式或e格式(选择输出时占宽度较小的一种),且不输出无意义的零。例如,若f=123.468,则
printf(”%f ㄩㄩ %eㄩㄩ %g”,f,f,f);
输出如下:
123.468000__1234680e+002__123.468___
10列 13列 10列
用%f格式输出占10列,用%e格式输出占13列,用%g格式时,自动从上面两种格式中选择短者(今以%f格式为短),故占10列,且按%f格式用小数形式输出,最后3个小数位为无意义的0,不输出,因此输出123.468,然后右补3个空格。%g格式用得较少。
以上介绍了9种格式符,归纳如表1。
表1 printf格式字符
格式字符 | 说明 |
d,i | 以带符号的十进制形式输出整数(正数不输出符号) |
o | 以八进制无符号形式输出整数(不输出前导符 0) |
x,X | 以十六进制无符号形式输出整数(不输出前导符0x)用x则输出十六进制数的a ~f时以小写形式输出。用X时,则以大写字母输出 |
u | 以无符号十进制形式输出整数 |
c | 以字符形式输出,只输出一个字符 |
s | 输出字符申 |
f | 以小数形式输出单、双精度数,隐含输出6位小数。 |
e.E | 以指数形式输出实数,用e时指数以“e”表示(如1.2+02),用E时指数以“E”表示(如1.2E+02) |
g,G | 选用%f或%e格式中输出宽度较短的一种格式,不输出无意义的0。用G时,若以指数形式输出,则指数以大写表示 |
在格式说明中,在%和上述格式字符间可以插入以下几种附加符号(又称修饰符)。
表2 printf的附加格式说明字符
字符 | 说明 |
字母l | 用于长整型整数,可加在格式符d.o、x、u前面 |
m(代表一个正整数) | 数据最小宽度 |
n(代表一个正整数) | 对实数,表示输出n位小数;对字符串,表示截取的字符个数 |
输出的数字或字符在域内向左靠 |
在用printf函数输出时,务必注意数据类型应与上述格式说明匹配,否则将会出现错误。
在使用printf函数时,还有几点要说明:
(1)除了X,E,G外,其他格式字符必须用小写字母,如%d不能写成%D。
(2)可以在printf函数中的“格式控制”字符串内包含的“转义字符”,如“\n”、“\t”、“\b”、“\r”、“\f”、“\377”等。
(3)上面介绍的d、o、x、u、c、s、f、e、g等字符,如用在“%”后面就作为格式符号。一个
格式说明以“%”开头,以上述9个格式字符之一为结束,中间可以插入附加格式字符(也称修饰符)。例如:
printf (”c=%cf=%fs=%s”,c, f, s) ;
格式说明
第一个格式说明为“%c”而不包括其后的f,第二个格式说明为“%f”,不包括其后的 s,第三个格式说明为%s。其他的字符为原样输出的普通字符。
- 如果想输出字符“%”,则应该在“格式控制”字符串中用连续两个%表示,如
printf (”%f%%”,1.0/3) ;
输出:0.333333%