Java中的浮点精度错误

前端之家收集整理的这篇文章主要介绍了Java中的浮点精度错误前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想知道什么是修复精度错误的最佳方法是在 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("");
    }
  }
}

显示的结果是:@H_301_5@

loop value: 11 @H_301_5@

20.789999@H_301_5@

loop value: 22@H_301_5@

41.579998@H_301_5@

loop value: 44@H_301_5@

83.159996@H_301_5@

loop value: 88@H_301_5@

166.31999@H_301_5@

loop value: 176@H_301_5@

332.63998@H_301_5@

loop value: 352@H_301_5@

665.27997@H_301_5@

loop value: 704@H_301_5@

1330.5599@H_301_5@

此外,如果有人可以解释为什么它只从11开始,并且每次都加倍价值.我认为所有其他值(或至少有很多)显示正确的结果.@H_301_5@

像这样的问题使我头疼,我通常使用数字格式化程序或将它们放在一个字符串中.@H_301_5@

编辑:正如人们所说,我可以使用一个double,但是在尝试之后,似乎是1.89作为双倍的792仍然输出一个错误(输出是1496.8799999999999).@H_301_5@

我想我会尝试其他解决方案,如BigDecimal@H_301_5@

解决方法

如果你真的关心精度,你应该使用BigDecimal

http://download.oracle.com/javase/1,5.0/docs/api/java/math/BigDecimal.html@H_301_5@

猜你在找的Java相关文章