3.2.1 float
我们将上面代码中的整型int替换为单精度浮点型float。
随后,我们再将printf("%d\n",a);中的占位符%d替换为%f,因为我们已经学过%d占位符用于整型,而%f占位符用于浮点型。
程序清单3.4是替换完成的代码。
程序清单 3.4
#include <stdio.h> int main(){ float a = 1.234567; float b = 0.00001; float c = 365.12345; printf("%f\n", a); printf("%f\n", b); printf("%f\n", c); return 0; }
图3.12显示了将int替换成float之后,大部分的数据都是正确的。但是365.12345变成了365.123444,很明显精度出现了误差。
图3.12 初识float类型
这是因为浮点数不能表示无限精确的值,它会存在一定的误差。
在C语言中,float类型可以表示6~7位有效数字(即精度),这取决于具体的实现和编译器。这意味着在进行计算时,对于小于或等于6~7位有效数字的数,float类型可以提供足够的精度,但对于更大的数,则可能存在舍入误差。
float 类型的取值为1.2×10−38~3.4×1038,也可以表示非常接近0的数字(如1.2−38),但是它的精度可能会受到限制。
因此,当我们使用float类型存储365.12345时,前面六位数值是准确的,但是后面的数值略有误差。