3.2.2 double

有没有比float精度更高的数据类型呢?有的,它被称为双精度浮点型double。我们将程序清单3.4中的float替换为double。

那么在printf函数中,我们是否需要更改使用的占位符呢?

答案是否定的。我们需要记住,在printf函数中,无论是使用float还是double,都可以使用%f作为占位符。程序清单3.5是更改后的代码。

程序清单 3.5

#include <stdio.h>
int main()
{
   double a = 1.234567;
   double b = 0.00001;
   double c = 365.12345;
   printf("%f\n", a);
   printf("%f\n", b);
   printf("%f\n", c);
   return 0;
}

结果如图3.13所示。我们可以看到,这次的结果365.12345也是正确的。

图3.13 初识double类型

但需要注意的是,double类型同样存在精度范围。对于更高精度的数据,double仍然会出现误差。

在日常应用中,我们通常不会苛求一个数值的精度完美无误,而允许一定的误差范围。但是,如果涉及高精度计算,需要采用特殊的方法进行数值计算,以尽量减少误差。