java 浮点数加减乘除精度丢失问题解决方法

使用

import java.math.BigDecimal;

另外需要注意,使用BigDecimal(double val)构造函数时仍会存在精度丢失问题,建议使用BigDecimal(String val)。这就需要先把double转换为字符串然后在作为BigDecimal(String val)构造函数的参数。转换为BigDecimal对象之后再进行加减乘除操作,这样精度就不会出现问题了。这也是为什么有关金钱数据存储都使用BigDecimal。

import java.math.BigDecimal;

public class testDouble {
    public static void main(String[] args) {
   
        double a = 1.3;
        double b = 32.123;
        System.out.println(Double.sum(a, b));//丢失精度
        System.out.println(a+b);
        BigDecimal bigDecimal = new BigDecimal(Double.toString(a));
        BigDecimal bigDecimalB = new BigDecimal(Double.toString(b));
        System.out.println(bigDecimal.add(bigDecimalB));//33.423
    }
}

 


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