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

java – Float和BigDecimal的精度差异

发布时间:2020-12-14 19:20:24 所属栏目:Java 来源:网络整理
导读:public static void main(String[] args) { // TODO Auto-generated method stub BigDecimal foo,foo1; foo=BigDecimal.valueOf(3.1); foo1=BigDecimal.valueOf(3.1f); System.out.println(foo); System.out.println(foo1);} 结果: 3.1 3.0999999046325684

public static void main(String[] args) {
    // TODO Auto-generated method stub
    BigDecimal foo,foo1;
    foo=BigDecimal.valueOf(3.1);
    foo1=BigDecimal.valueOf(3.1f);

    System.out.println(foo);
    System.out.println(foo1);

}

结果:
3.1
3.0999999046325684
为什么他们的结果不同?我使用的是JDK1.7.0_03

最佳答案
3.1定义一个double而3.1f定义一个float.你看到的是float表示该值的问题(float使用“仅”32位和双64位).

如果要使用BigDecimal精确定义3.1,请使用String构造函数:

BigDecimal foo = new BigDecimal("3.1");
System.out.println(foo);

输出:

3.1

(编辑:李大同)

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

    推荐文章
      热点阅读