C语言之printf函数

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)长度
长度格式符为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个空格。
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值