1.定义了一个数值:2.0E30 分别使用float double long double进行定义 再使用printf打印
2. 打印发现结果各不相同???
3.
#include<stdio.h>
int main(void)
{
/*int bg = 0XAA;*/
float bg1 = 2.0e30;
printf("%f\n", bg1);
double bg2 = 2.0e30;
printf("%f\n", bg2);
long double bg3 = 2.0e30;
printf("%f\n", bg3);
}
4.输出值为:
2000000030094932439753377710080.000000
2000000000000000039769249677312.000000
2000000000000000039769249677312.000000
浮点数精度有限,这也是浮点数不能用=判断等的原因
%f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。
其中:
float,单精度浮点型,对应%f.
double,双精度浮点型,对应%lf.
在用于输出时:
float类型可以使用%lf格式,但不会有任何好处。
double类型如果使用了%f格式可能会导致输出错误。
在用于输入时:
double 类型使用了%f格式,会导致输入值错误。
float类型使用double类型不仅会导致输入错误,还可能引起程序崩溃。
所以在输入输出时,一定要区分好double和float,而使用对应的格式符号。
记住%LF