C语言—printf()

作者:追风剑情 发布于:2019-7-16 21:34 分类:C

示例:


#include <stdio.h>
int main(void)
{
	int x = 100;//十进制
	int x1 = 0100;//八进制
	int x2 = 0x100;//或0X100 十六进制
	long x3 = 100L;//或100l
	long x4 = 020L;
	long x5 = 0x10L;
	long long x6 = 3LL;
	unsigned long long x7 = 3ULL;//或3ull
	unsigned long long x8 = 3LLU;//或2llu

	long int estine = 99;
	long johns;//等效于long int johns;
	short int erns = 98;
	short ribs;//等效于short int ribs;
	//C90标准新增的
	unsigned int s_count = 100;
	unsigned players;
	unsigned long headcount;
	unsigned short yesvotes;
	//long long类型是C99标准新增的
	long long ago;//等效于long long int ago;

	//在printf()中只能使用小写%?
	printf("s_count = %u; estine = %ld", s_count, estine);
	printf("dec = %d; octal = %o; hex = %x \n", x, x, x);
	//ld, lo, lx表示long类型的的10进制,8进制,16进制
	printf("dec = %ld; octal = %lo; hex = %lx \n", x3, x3, x3);
	//h表示short
	printf("dec = %hd; octal = %ho; hex = %hx \n", erns, erns, erns);
	//如果要显示各进制前缀,需要加#
	printf("dec = %d; octal = %#o; hex = %#x \n", x, x, x);
	//%lu表示unsigned long
	//%lld表示long long
	//%llu表示unsigned long long

	//打印浮点数
	float aboat = 32000.0;
	double abet = 2.14e9;
	long double dip = 5.32e-5;
	//%f打印十进制记数的float
	//%e打印指数记数的float
	//如果系统支持十六进制格式的浮点数,可用a和A分别代替e和E
	//%Lf、%Le、%La打印long double
	printf("aboat=%a, abet=%f; abet=%e \n", aboat, abet, abet);
	printf("dip=%Lf; dip=%Le \n", dip, dip);

	//C99和C11提供%zd用来打印sizeof()的返回值,
	//不支持C99和C11的编译器可用%u或%lu代替%zd
	printf("size=%zd \n", sizeof(long long));

	//多个用双引号括起的字符串可以连接
	//下面两句代码等价
	printf("a""b" "c" "\n");
	printf("abc\n");

	getchar();
	return 0;
}


运行测试

1111.png

转换说明及其打印的输出结果
转换说明 输出
%a 浮点数、十六进制数和p记数法( C99/C11 )
%A 浮点数、十六进制数和p记数法( C99/C11 )
%c 单个字符
%d 有符号十进制整数
%e 浮点数,e记数法
%E 浮点数,e记数法
%f 浮点数,十进制记数法
%g 根据值的不同,自动选择%f或%e。%e格式用于指数小于-4或者大于或等于精度时
%G 根据值的不同,自动选择%f或%E。%E格式用于指数小于-4或者大于或等于精度时
%i 有符号十进制整数(与%d相同)
%o 无符号八进制整数
%p 指针
%s 字符串
%u 无符号十进制整数
%x 无符号十六进制整数,使用十六进制数0f
%X 无符号十六进制整数,使用十六进制数0F
%% 打印一个百分号

printf()的修饰符
修饰符 含义
标记 5种标记(-、+、空格、#、0),可以不使用标记或使用多个标记。示例:"%-10d"
数字 最小字段宽度
如果该字段不能容纳待打印的数字或字符串,系统会使用更宽的字段。示例:”%4d“
.数字 精度
对于%e、%E和%f转换,表示小数点右边数字的位数
对于%g和%G转换,表示有效数字最大位数
对于%s转换,表示待打印字符的最大数量
对于整数转换,表示待打印数字的最小位数
如有必要,使用前导0来达到这个位数
只使用.表示其后跟随一个0,所以%.f和%.0f相同
示例:”%5.2f“打印一个浮点数,字段宽度为5字符,其中小数点后有两位数字
h 和整型转换说明一起使用,表示short int 或 unsigned short int 类型的值
示例:”%hu、%hx、%6.4hd“
hh 和整型转换说明一起使用,表示signed char 或 unsigned char 类型的值
示例:”%hhu、%hhx、%6.4hd“
j 和整型转换说明一起使用,表示intmax_t 或 uintmax_t 类型的值。这些类型定义在stdint.h中
示例:”%jd、%8jx“
l 和整型转换说明一起使用,表示long int 或 unsigned long int 类型的值
示例:”%ld、%8ld“
ll 和整型转换说明一起使用,表示long long int 或 unsigned long long int 类型的值(C99)
示例:”%lld、%8llu“
L 和整型转换说明一起使用,表示long double 类型的值
示例:”%Ld、%10.4Le“
t 和整型转换说明一起使用,表示ptrdiff_t 类型的值。ptrdiff_t是两个指针差值的类型(C99)
示例:”%td、%12ti“
z 和整型转换说明一起使用,表示size_t 类型的值。size_t是sizeof返回的类型(C99)
示例:”%zd、%12zd“

printf()的标记
标记 含义
- 待打印项左对齐。即,从字段的左侧开始打印该项。
示例:“%-20s”
+ 有符号值若为正,则在值前面显示加号;若为负,则在值前面显示减号
示例:“%+6.2f”
空格 有符号值若为正,则在值前面显示前导空格(不显示任何符号);若为负,则在值前面显示减号,+标记覆盖一个空格
示例:“%6.2f” 
# 把结果转换为另一种形式。如果是%o格式,则以0开始;如果是%x或%X格式,则以0x或0X开始;对于所有的浮格式,#保证了即使后面没有任何数字,也打印一个小数点字符。对于%g或%G格式,#防止结果后面的0被删除
示例:“%#o、%#8.0f、%+#10.3e”
0 对于数字格式,用前导0代替空格填充字段宽度。对于整数格式同,如果出现-标记或指定精度,则忽略该标记

注意   float参数的转换
      对于浮点类型,有用于double和long double类型的转换说明,却没有float类型的。这是因为在K&R C中,表达式或参数中的float类型值会被自动转换成double类型。一般而言,ANSIC不会把float自动转换成double。然而,为保护大量假设float类型的参数被自动转换成double的现有程序,printf()函数中所有float类型的参数(对未使用显示原型的所有C函数都有效)仍自动转换成double类型。因此,无论是K&R C还是ANSI C,都没有显示float类型值专用的转换说明。

示例:打印不同字段宽度的整数

//Visual Studio中加上这句才可以使用scanf()
//否则只能使用scanf_s()
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>

#define PAGES 959

int main(void)
{
	printf("*%d*\n", PAGES);
	//打印两个字段宽度
	printf("*%2d*\n", PAGES);
	//打印10个字段宽度且右对齐
	printf("*%10d*\n", PAGES);
	//打印10个字段宽度且左对齐
	printf("*%-10d*\n", PAGES);

	system("pause");
	return 0;
}

运行测试
111.png

标签: C语言

Powered by emlog  蜀ICP备18021003号   sitemap

川公网安备 51019002001593号