Java中的高精度问题解决

  • Post author:
  • Post category: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);

但是这里有几个注意事项

首先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));

版权声明:本文为qq_61057438原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。