解决浮点运算精度不准确,BigDecimal 加减乘除

Posted eternityz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决浮点运算精度不准确,BigDecimal 加减乘除相关的知识,希望对你有一定的参考价值。

package com.kflh.boxApi.utils.util;

import java.math.BigDecimal;

/**
 * @program: BoxApi
 * @description: 计算浮点数
 * @author: eterntiyz
 * @create: 2019-01-17 11:10
 */
public class DoubleCalendar {

    /** 
     * @Description: 浮点加法
     * @Param: [] 
     * @return: java.lang.Double 
     * @Author: tonyzhang 
     * @Date: 2019-01-17 11:27
     */ 
    public static Double add(String str1,String str2) {
        BigDecimal bignum1 = new BigDecimal(str1);
        BigDecimal bignum2 = new BigDecimal(str2);
        BigDecimal bignum3 = bignum1.add(bignum2);
        return bignum3.doubleValue();
    }

    /** 
     * @Description: 浮点减法 
     * @Param: [] 
     * @return: java.lang.Double 
     * @Author: tonyzhang 
     * @Date: 2019-01-17 11:27
     */ 
    public static Double subtract(String str1,String str2) {
        BigDecimal bignum1 = new BigDecimal(str1);
        BigDecimal bignum2 = new BigDecimal(str2);
        BigDecimal bignum3 = bignum1.subtract(bignum2);
        return bignum3.doubleValue();
    }

    /**
     * @Description: 浮点乘法
     * @Param: str1为分母,str2为分子
     * @return: java.lang.Double
     * @Author: tonyzhang
     * @Date: 2019-01-17 11:26
     */
    public static Double multiply(String str1,String str2) {
        BigDecimal bignum1 = new BigDecimal(str1);
        BigDecimal bignum2 = new BigDecimal(str2);
        BigDecimal bignum3 = bignum1.multiply(bignum2);
        return bignum3.doubleValue();
    }

    /**
     * @Description: 浮点除法
     * @Param: []
     * @return: java.lang.Double
     * @Author: tonyzhang
     * @Date: 2019-01-17 11:26
     */
    public static Double divide(String str1,String str2) {
        BigDecimal bignum1 = new BigDecimal(str1);
        BigDecimal bignum2 = new BigDecimal(str2);
        //参数意义.bignum1为分母,bignum2为分子,scale保留的位数,BigDecimal.ROUND_DOWN表示不进位
        BigDecimal bignum3 = bignum1.divide(bignum2,2,BigDecimal.ROUND_DOWN);
        return bignum3.doubleValue();
    }

    public static void main(String[] args) {
        System.out.println(divide("4600.0","0.6"));
    }
}

以上是关于解决浮点运算精度不准确,BigDecimal 加减乘除的主要内容,如果未能解决你的问题,请参考以下文章

BigDecimal类处理高精度计算

Java BigDecimal类

java中BigDecimal加减乘除基本用法

Java 使用BigDecimal类处理高精度计算

Java之BigDecimal 使用总结

JS解决加减乘除浮点类型丢失精度问题