printf函数(格式输出函数)

本文详细介绍了C语言中的printf函数,包括其一般格式、输出表列、各种格式字符(如%d, %o, %x, %c, %s, %f, %e, %g)的使用方法和示例,以及在输出时的附加格式说明字符和注意事项。" 125030114,7925799,WCN685X温度控制逻辑与PID算法解析,"['WiFi', 'PID控制', '芯片散热', '无线通信']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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. 格式字符

对不同类型的数据用不同的格式字符。常用的有以下几种格式字符:

  1. 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

  1. 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

  1. 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列补空格。

  1. 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。其他的字符为原样输出的普通字符。

  1. 如果想输出字符“%”,则应该在“格式控制”字符串中用连续两个%表示,如

printf (”%f%%”,1.0/3) ;

输出:0.333333%

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阳光向日葵向阳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值