C语言printf()函数:格式化输出函数

时间:2023-03-08 22:44:57
C语言printf()函数:格式化输出函数

C语言printf()函数:格式化输出函数

头文件:#include <stdio.h>
printf()函数是最常用的格式化输出函数,其原型为:
    int printf( char * format, ... );

printf()会根据参数 format 字符串来转换并格式化数据,然后将结果输出到标准输出设备(显示器),直到出现字符串结束('\0')为止。

参数 format 字符串可包含下列三种字符类型:

  • 一般文本,将会直接输出
  • ASCII 控制字符,如\t、\n 等有特定含义
  • 格式转换字符

格式转换为一个百分比符号(%)及其后的格式字符所组成。一般而言,每个%符号在其后都必需有一个参数与之相呼应(只有当%%转换字符出现时会直接输出%字符),而欲输出的数据类型必须与其相对应的转换字符类型相同。

printf()格式转换的一般形式如下:
    %(flags)(width)(. prec)type
以括号括起来的参数为选择性参数,而%与type 则是必要的,下面介绍 type 的几种形式。

1) 整数

  • %d  整数的参数会被转成有符号的十进制数字
  • %u  整数的参数会被转成无符号的十进制数字
  • %o  整数的参数会被转成无符号的八进制数字
  • %x  整数的参数会被转成无符号的十六进制数字,并以小写abcdef 表示
  • %X  整数的参数会被转成无符号的十六进制数字,并以大写ABCDEF 表示浮点型数
  • %f double  型的参数会被转成十进制数字,并取到小数点以下六位,四舍五入
  • %e double  型的参数以指数形式打印,有一个数字会在小数点前,六位数字在小数点后,而在指数部分会以小写的e 来表示
  • %E 与%e 作用相同,唯一区别是指数部分将以大写的E 来表示
  • %g double  型的参数会自动选择以%f 或%e 的格式来打印,其标准是根据打印的数值及所设置的有效位数来决定。
  • %G 与%g 作用相同,唯一区别在以指数形态打印时会选择%E 格式。

2) 字符及字符串

  • %c 整型数的参数会被转成unsigned char 型打印出
  • %s 指向字符串的参数会被逐字输出,直到出现NULL 字符为止
  • %p 如果是参数是"void *"型指针则使用十六进制格式显示

prec 有几种情况:

  • 正整数的最小位数
  • 在浮点型数中代表小数位数
  • 格式代表有效位数的最大值
  • 在%s 格式代表字符串的最大长度
  • 若为×符号则代表下个参数值为最大长度

width 为参数的最小长度,若此栏并非数值,而是*符号,则表示以下一个参数当做参数长度。

flags 有下列几种情况

  • +  一般在打印负数时,printf ()会加印一个负号,整数则不加任何负号,此旗标会使得在打印正数前多一个正号 (+)。
  • #  此旗标会根据其后转换字符的不同而有不同含义。当在类型为o 之前 (如%#o),则会在打印八进制数值前多印一个o。而在类型为x 之前 (%#x)则会在打印十六进制数前多印'0x',在型态为e、E、f、g 或G 之前则会强迫数值打印小数点。在类型为g 或G 之前时则同时保留小数点及小数位数末尾的零。
  • 0  当有指定参数时,无数字的参数将补上0。默认是关闭此旗标,所以一般会打印出空白字符。

【返回值】成功则返回写入的字符数目。

如果发生写入错误,将会设置文件错误标志(可通过 ferror() 检测),并返回一个负数。

如果在写入宽字符时一个多字节的字符发生编码错误,那么 errno 将被设置为 EILSEQ,并返回一个负数。

printf( format, ... ) 等价于 fprintf(stdout, format, ...),更多信息请参考 fprintf() 函数。

【实例】分别输出整数、浮点数和字符串。

  1. #include<stdio.h>
  2. int main(void)
  3. {
  4. int a=1;
  5. float b=5.0;
  6. char str[100]= "";
  7. scanf("%c %c %c",&a,&b,str);
  8. /*分别演示 整数*/
  9. printf("int is:%d\n",a);
  10. /*分别演示 浮点数*/
  11. printf("float is:%f\n",b);
  12. /*分别演示 字符串*/
  13. printf("char is:%s\n",str);
  14. return 0;
  15. }

输出结果:
【运行结果】
1 4.4 fs
int is:1
float is:4.400000
char is:fs

例子首先是等待用户输入整数浮点数和一个字符串,然后调用函数printf()按照对应的格式输出。

又如,输出更多格式的数据。

  1. #include <stdio.h>
  2. int main()
  3. {
  4. printf ("Characters: %c %c \n", 'a', 65);
  5. printf ("Decimals: %d %ld\n", 1977, 650000L);
  6. printf ("Preceding with blanks: %10d \n", 1977);
  7. printf ("Preceding with zeros: %010d \n", 1977);
  8. printf ("Some different radices: %d %x %o %#x %#o \n", 100, 100, 100, 100, 100);
  9. printf ("floats: %4.2f %+.0e %E \n", 3.1416, 3.1416, 3.1416);
  10. printf ("Width trick: %*d \n", 5, 10);
  11. printf ("%s \n", "A string");
  12. return 0;
  13. }

输出结果:
Characters: a A
Decimals: 1977 650000
Preceding with blanks:       1977
Preceding with zeros: 0000001977
Some different radices: 100 64 144 0x64 0144
floats: 3.14 +3e+000 3.141600E+000
Width trick:    10
A string