加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java中的浮点精度错误

发布时间:2020-12-14 16:23:44 所属栏目: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.prin
我想知道什么是修复精度错误的最佳方法是在 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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读