关于C语言的%g和%G简要说明

转换声明%g和%G的输出

01、%g和%G的使用说明

在书籍 《C primer Plus》 中4.4节有提到printf函数的“转化说明”,比如常用的整型输出转化说明:%d,可以用来输出一个整型。

#include
int main()
{
	int n=2;
	printf("%d",n);	
	return 0;
}

然后对于“转化说明”%g和%G的描述是这样的:

转化说明 输出
%g 根据值的不同,自动选择%f或%e,%e格式用于指数小于-4或者大于或等于精度时
%G 根据值的不同,自动选择%f或%E,%E格式用于指数小于-4或者大于或等于精度时

简单来说,当一个浮点数转为指数计数法时:

  • ①指数>=6或者<-4的时候:%g(%G)选择 %e(%E)输出
  • ②指数其余情况:都是选择%f输出

指数计数法:比如20表示为0.2 * 102 就是使用指数计数法计数,其中10上面的“2”就是0.2 * 102 的指数。

而%g和%G的区别仅仅是输出指数表达式的时候,10时写成e还是E,两者几乎没有用区别。

02、废话不多说直接上代码

#include
int main()
{
	//指数>=6
	double a, b, c, d;
	double e, f, g, h;
	a = 12345678;
	b = 1234567;
	c = 123456;
	d = 12345;
	printf("①指数>=6或者<-4的时候:%%g(%%G)选择 %%e(%%E)输出\n"
		   "②其余情况:都是选择%%f输出\n\n");

	printf("指数>=6的时候\n");
	printf("%%f\t\t  %%e\t\t  %%g\t\t  %%G\n");
	printf("%f\t  %e\t  %g\t  %G\n", a, a, a, a);
	printf("%f\t  %e\t  %g\t  %G\n", b, b, b, b);
	printf("%f\t  %e\t  %g\t  %G\n", c, c, c, c);
	printf("%f\t  %e\t  %g\t\t  %G\n", d, d, d, d);
	printf("\n");
	//指数<=-4
	e = 0.000001;
	f = 0.00001;
	g = 0.0001;
	h = 0.001;
	printf("指数<=-4的时候\n");
	printf("%%f\t\t  %%e\t\t  %%g\t\t  %%G\n");
	printf("%f\t  %e\t  %g\t\t  %G\n", e, e, e, e);
	printf("%f\t  %e\t  %g\t\t  %G\n", f, f, f, f);
	printf("%f\t  %e\t  %g\t  %G\n", g, g, g, g);
	printf("%f\t  %e\t  %g\t\t  %G\n", h, h, h, h);
	return 0;
}

程序结果为:
关于C语言的%g和%G简要说明_第1张图片

另外还可以注意到%g(%G)在选择%f输出的时候,是不会有多余的0出现的。例如:本代码的结果中,前面的%f输出还是12345.000000,后面的%g(%G)仅仅输出了12345

而防止多余的0被删除的方法就是在%后面加上修饰符#。

你可能感兴趣的:(C语言杂货笔记,c语言,c++,开发语言)