Java中的高精度问题解决办法

因为double精度的原因,在我们日常编码中常常会遇到各种各样的精度问题
例如

System.out.println(0.1+0.2);

 在这里插入图片描述

这些问题常常让人头大,之前在c语言中,我们可以通过将数字转化成字符串,然后进行高精度的运算,而在java中同样可以如此操作,而且Java还贴心的将他封装好了

我们可以通过BigDecimal类来实现

 BigDecimal a=BigDecimal.valueOf(10.0);
        BigDecimal b=BigDecimal.valueOf(6.0);
        //加法
        BigDecimal r1=a.add(b);
        //减法
        BigDecimal r2=a.subtract(b);
        //乘法
        BigDecimal r3=a.multiply(b);
        //除法
        BigDecimal r4=a.divide(b,2, RoundingMode.HALF_UP);
        System.out.println(r1);
        System.out.println(r2);
        System.out.println(r3);
        System.out.println(r4);
 

 valueOf:.由基本数据型态转换成String

但是这里有几个注意事项

首先BigDecimal对象不能由一个double类型直接转换,会导致精度的问题,需要用valueof来避免,或用toString

但是查看vlaueof的源码就会发现,实际上二者没有什么区别,都是取转化成String类型

 

public static BigDecimal valueOf(double val) {
        // Reminder: a zero double returns '0.0', so we cannot fastpath
        // to use the constant ZERO.  This might be important enough to
        // justify a factory approach, a cache, or a few private
        // constants, later.
        return new BigDecimal(Double.toString(val));
    }
 

其次在计算除法的时候要注意一些无法整除的情况
因为BigDecimal一定为精度运算,因而这种情况会导致程序的崩溃
因而要在除法加入保留几位小数 

//保留2位小数,四舍五入
BigDecimal r4=a.divide(b,2, RoundingMode.HALF_UP);
 

然后要注意比较数据大小是否相同要用compareto 

    BigDecimal bigDecimal1 = BigDecimal.valueOf(0.01);
    BigDecimal bigDecimal2 = BigDecimal.valueOf(0.01);
    System.out.println(bigDecimal1.compareTo(bigDecimal2));
 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值