我想知道什么是修复精度错误的最佳方法是在
Java中.如下例所示,有精度错误:
class FloatTest { public static void main(String[] args) { Float number1 = 1.89f; for(int i = 11; i < 800; i*=2) { System.out.println("loop value: " + i); System.out.println(i*number1); System.out.println(""); } } }
显示的结果是:
loop value: 11
20.789999
loop value: 22
41.579998
loop value: 44
83.159996
loop value: 88
166.31999
loop value: 176
332.63998
loop value: 352
665.27997
loop value: 704
1330.5599
此外,如果有人可以解释为什么它只从11开始,并且每次都加倍价值.我认为所有其他值(或至少有很多)显示正确的结果.
像这样的问题使我头疼,我通常使用数字格式化程序或将它们放在一个字符串中.
编辑:正如人们所说,我可以使用一个double,但是在尝试之后,似乎是1.89作为双倍的792仍然输出一个错误(输出是1496.8799999999999).
我想我会尝试其他解决方案,如BigDecimal
解决方法
如果你真的关心精度,你应该使用BigDecimal
http://download.oracle.com/javase/1,5.0/docs/api/java/math/BigDecimal.html