[声明]所有代码均来自Joshua Bloch和Neal Gafter所著的<Java解惑>一书,本人仅因学习需要摘抄和注释,感谢二位作者的知识分享.
代码:
public class Change {
public static void main(String args[]) {
System.out.println(2.00 - 1.10);
}
}
结果:
0.8999999999999999
分析:
在JAVA中二进制浮点数并不能完全精确的表示小数,我们看到的浮点数的实际值是无限接近字面值的数值.
例如:1.10字面值是1.10,但是这个浮点数在计算机中的实际值可能是1.11111111111.
所以计算的结果可能没达到我们的预期.
所以在计算浮点数运算时通常使用精度更高更准确的BigDecimal类.
代码:
public class Change {
public static void main(String args[]) {
System.out.println(new BigDecimal("2.00").subtract(new BigDecimal("1.10")));
}
}
结果:
0.90
注意在实例化BigDecimal时,如果用浮点数做参数来实例化,并不能得到正确结果,因为浮点数的实际值并非预期值.
解决方案代码:
public class Change {
public static void main(String args[]) {
System.out.println(new BigDecimal(2.00).subtract(new BigDecimal(1.10)));
}
}
结果:
0.899999999999999911182158029987476766109466552734375