C++中printf格式化输出整理

目录

printf格式字符串

实际测试结果

参考资料


printf格式字符串

格式控制字符 输出数据类型 标 志 意义

%p

指针 - 结果左对齐,右边填空格

%c

char + 输出符号(正号或负号)

%s

string 空格 输出值为正时冠以空格,为负时冠以负号
%f float # 对c、s、d、u类无影响;
对o类,在输出时加前缀o;
对x类,在输出时加前缀0x;
%lf      

%a(%A)

浮点数、十六进制数字和p-(P-)记数法(C99)

   

%e(%E)

浮点数指数输出[e-(E-)记数法]

 

%g(%G)

浮点数不显无意义的零"0"

 
%d/%i int 格式字符串
%ld long [标志][输出最少宽度][.精度][长度]类型
%lld long long

用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。

%u

无符号十进制整数

精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。

%o

八进制整数    

%x(%X)

十六进制整数0f(0F)    

%%

%    

 

 

 

 

 

 

 

 

 

 

 

 

 

 

实际测试结果

#include 
#include 

int main()
{
	char c;
	int i1 = -78;
	int i2 = 78;
	unsigned int u = 78;
	long l = 1234567890;
	long long ll = 1234567890123456789;
	float f1 = 3.123456;
	float f2 = 3.100000;
	double x = 123.12345678912345;
	std::string s = "Hello,world";
	c = '\x41';
	
	printf("i1 = %d\n", i1); //%d,十进制int,i1 = -78
	
	printf("i2 = %d\n", i2); //%d,十进制int,i2 = 78
	
	printf("i1 = %i\n", i1); //%d,十进制int,i1 = -78
	
	printf("i2 = %d\n", i2); //%d,十进制int,i2 = 78
	
	printf("u = %u\n", u); //%u,无符号十进制int,u = 78

	printf("i2 = %d%%\n", i2); //%d,十进制int,%%输出%号,i2 = 78%

	printf("i1 = %o\n", i1); //%o,八进制int,不输出o,i1 = 37777777662

	printf("i2 = %o\n", i2); //%o,八进制int,不输出o,i2 = 116

	printf("i2 = %#o\n", i2); //%o,八进制int,#输出o,i2 = o116
	
	printf("i1 = %x\n", i1); //%x,十六进制int,不输出0x,i1 = ffffffb2

	printf("i2 = %x\n", i2); //%x,十六进制int,不输出0x,i2 = 4e

	printf("i2 = %X\n", i2); //%X,十六进制int,不输出0X,i2 = 4E
	
	printf("i2 = %#x\n", i2); //%x,十六进制int,#输出0x,i2 = 0x4e
	
	printf("i2 = %08d\n", i2); //%d,十进制int,8表示输出最小宽度,超过按实际位数,不足的左边补0,i2 = 00000078

	printf("i2 = %+8d\n", i2); //%d,十进制int,+输出+号,8表示输出最小宽度,超过按实际位数,不足的左边补空格,i2 =      +78

	printf("i2 = %-8d\n", i2); //%d,十进制int,-左对齐,8表示输出最小宽度,超过按实际位数,不足的右边补空格,i2 = 78     

	printf("i1 = % d\n", i1); //%d,十进制int,空格表示输出值为正时加空格,为负时加-号,i1 = -78

	printf("i2 = % d\n", i2); //%d,十进制int,空格表示输出值为正时加空格,为负时加-号,i2 =  78

	printf("l = %ld\n", l); //%ld,十进制long,l = 1234567890
	
	printf("ll = %lld\n", ll); //%lld,十进制long long,ll = 1234567890123456789

	printf("f1 = %f\n", f1); //%f,float,有效数字是7位,f1 = 3.123456
	
	printf("f1 = %6.10f\n", f1); //%f,float,有效数字是7位,最少输出6位,小数点后有8位,超出范围,f1 = 3.1234560013

	printf("f1 = %a\n", f1); //%a,十六进制和p-记数法,float,有效数字是7位,f1 = 0x1.8fcd680000000p+1

	printf("f1 = %A\n", f1); //%A,十六进制和P-记数法,float,有效数字是7位,f1 = 0x1.8Fcd680000000P+1
	
	printf("f1 = %e\n", f1); //%e,指数e-记数法,float,有效数字是7位,f1 = 3.123456e+00

	printf("f2 = %E\n", f2); //%E,指数E-记数法,float,有效数字是7位,f2 = 3.100000E+00
	
	printf("f2 = %g\n", f2); //%g,不显示无意义的0,float,有效数字是7位,f2 = 3.1

	printf("x = %lf\n", x); //%x,double,x = 123.123457

	printf("x = %10.14lf\n", x); //%x,double,x = 123.12345678912345
	
	printf("c = %c\n", c); //%c,char,c = A
	
	printf("c = %x\n", c); //%x,以十六进制输出字符ascll码,c = 41

	printf("s = %s\n", s.c_str()); //%s,输出字符串,s = Hello,world

	printf("s = %6.9s\n", s.c_str()); //%s,输出字符串,最多输出9个字符,s = Hello,wor
	
	printf("s = %10.9s\n", s.c_str()); //%s,输出字符串,最多输出9个字符,不足左边补空格,s =  Hello,wor

	system("pause");
	return 0;
}

参考资料

【C++】printf格式化输出:https://blog.csdn.net/u013066730/article/details/84243819

C++---常用printf输出格式:https://blog.csdn.net/qq_40951833/article/details/103104812

你可能感兴趣的:(c++,printf)