前端之家收集整理的这篇文章主要介绍了
Float vs double Math Java,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
以下是否存在精度差异(假设a和b的值可以在浮点数中表示而
不会丢失精度).
有花车:
float a;
float b;
double result = 1 + a*b;
双打:
double a;
double b;
double result = 1 + a*b;
简单的例子:
float a = 16777217; // Largest int exactly representable in a float.
float b = 16777217;
System.out.println((double)(1 + a*b));
double c = 16777217;
double d = 16777217;
System.out.println(1 + c*d);
输出(Ideone):
2.81474976710656E14
2.8147501026509E14
所以是的,使用float会导致精度下降.
原文链接:https://www.f2er.com/css/242276.html