printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。
可以通过以下几个方面进行讨论printf函数:1、printf函数调用的一般格式。
printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。printf函数调用的一般形式为:printf(“格式控制字符串”, 输出表列)
其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,
以说明输出数据的类型、形式、长度、小数位数等。
#include <stdio.h>
int main(void)
{
int a=88,b=89;
printf("%d %d\n",a,b);
printf("%d,%d\n",a,b);
printf("%c,%c\n",a,b);
printf("a=%d,b=%d",a,b);
return 0;
}
通过上面的代码我们可以看出printf的格式,由于格式控制串不同,输出的结果也不相同。第1行的输出语句格式控制串中,两格式串%d 之间加了一个空格(非格式字符),所以输出的a、b值之间有一个空格。第2行的printf语句格式控制串中加入的是非格式字符逗号,因此输出的a、b值之间加了一个逗号。第3行的格式串要求按字符型输出a、b值。第6行中为了提示输出结果又增加了非格式字符串。
2、printf函数格式中的格式字符串。
格式字符串的一般形式为: [标志][输出最小宽度][.精度][长度]类型。
(1)类型
#include<stdio.h>
#include<stdlib.h>
int main(void)
{
int x=34,y=-34;
printf("x=%8d,y=%8d\n",x,y);//表明最小宽度为8,用空格进行填充
printf("x=%08d,y=%08d\n",x,y);//用0而不是用空格进行填充
printf("x=% 08d,y=% 08d\n",x,y);//空格总是产生一个-号或者是空格
printf("x=%-8d,y=%-8d\n",x,y);//-号表示的是左对齐
printf("x=%- 8d,y=%- 8d\n",x,y);
printf("x=%-+8d,y=%-+8d\n",x,y);//+总是产生一个+或-号
printf("x=%8.4d,y=%8.4d\n",x,y);//精度.4表示是四位有效数字
printf("x=%-8.4d,y=%-8.4d\n",x,y);
system("pause");
return 0;
}
(2)最小宽度
用十进制整数来表示输出的最少位数。
/*
当转换值的字符数(含前缀)小于最小宽度说明时,则使用填充符将数值填充到最小宽度.
当转换值的字符数(含前缀)大于最小宽度说明时,最小宽度说明失效。
*/
#include<stdio.h>
#include<stdlib.h>
int main(void)
{
int x=45,y=-45678;
printf("%9d,%3d",x,y);
system("pause");
return 0;
}
(3)精度
精度格式符以“.”开头,后跟十进制整数。
本项的意义是:
如果输出数字,则表示小数的位数;
如果输出的是字符,则表示输出字符的个数;
若实际位数大于所定义的精度数,则截去超过的部分。
(4)长度
(4)长度
长度格式符为h、l两种,h表示按短整型量输出,l表示按长整型量输出。
(5)类型
格式字符 | 意义 |
d | 以十进制形式输出带符号整数(正数不输出符号) |
o | 以八进制形式输出无符号整数(不输出前缀0) |
x,X | 以十六进制形式输出无符号整数(不输出前缀Ox) |
u | 以十进制形式输出无符号整数 |
f | 以小数形式输出单、双精度实数 |
e,E | 以指数形式输出单、双精度实数 |
g,G | 以%f或%e中较短的输出宽度输出单、双精度实数 |
c | 输出单个字符 |
s | 输出字符串 |
#include<stdio.h>
#include<stdlib.h>
int main(void)
{
int x=31;
float f=0.1;
char a[10]="abcde";
printf("%7.3d\n",x);
printf("%7.3x\n",x);//进行无符号十六进制的转换
printf("%7.3o\n",x);//进行无符号八进制的转换
printf("%7.1E\n",f);
printf("%7.3f\n",f);
printf("%7.3s\n",a);
system("pause");
return 0;
}
3、实例
#include <stdio.h>
int main(void)
{
int a=15;
long float b=123.1234567;
double c=12345678.1234567;
char d='p';
printf("a=%d\n", a);
printf("a(%%d)=%d, a(%%5d)=%5d, a(%%o)=%o, a(%%x)=%x\n\n",a,a,a,a); // %% 可以输出 %
printf("a=%f\n", b);
printf("b(%%f)=%f, b(%%lf)=%lf, b(%%5.4lf)=%5.4lf, b(%%e)=%e\n\n",b,b,b,b);
printf("c=%f\n", c);
printf("c(%%lf)=%lf, c(%%f)=%f, c(%%8.4lf)=%8.4lf\n\n",c,c,c);
printf("d=%c\n", d);
printf("d(%%c)=%c, d(%%8c)=%8c\n",d,d);
return 0;
}
从代码中我们可以看:
以四种格式输出整型变量a的值,其中“%5d ”要求输出宽度为5,而a值为15只有两位故补三个空格。
以四种格式输出实型量b的值。其中“%f”和“%lf ”格式的输出相同,说明“l”符对“f”类型无影响。“%5.4lf”指定输出宽度为5,精度为4,由于实际长度超过5故应该按实际位数输出,小数位数超过4位部分被截去。
输出双精度实数,“%8.4lf”由于指定精度为4位故截去了超过4位的部分。
输出字符量d,其中“%8c ”指定输出宽度为8故在输出字符p之前补加7个空格。