java中的精度计算--BigDecimal

Posted 江西昊仔

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java中的精度计算--BigDecimal相关的知识,希望对你有一定的参考价值。

对于一些精度的计算,我们需要使用java.math包下的BigDecimal类,确保他们的精度是我们需要的结果

BigDecimal.valueOf(a)  将a包装成BigDecimal类
import java.math.BigDecimal;
import static java.math.BigDecimal.*;

public class TestDouble {
    public static void main(String[] args) {
        double a = 11;
        double b = 3;
        // 对于一些精度的计算,我们需要使用java.math包下的BigDecimal,确保他们的精度是我们需要的结果

        // 加法--add
        System.out.println(
                a+" + "+b+"  =  "+BigDecimal.valueOf(a).add(BigDecimal.valueOf(b))
        );
        // 减法--subtract
        System.out.println(
                a+" - "+b+"  =  "+BigDecimal.valueOf(a).subtract(BigDecimal.valueOf(b))
        );
        // 乘法
        System.out.println(
                a+" * "+b+"  =  "+BigDecimal.valueOf(a).multiply(BigDecimal.valueOf(b))
        );

        // 除法--divide
        // ROUND_DOWN  接近零的舍入模式。
        System.out.println(
                a+" / "+b+"="+BigDecimal.valueOf(a).divide(BigDecimal.valueOf(b),5, ROUND_DOWN )
        );
        // ROUND_FLOOR  接近负无穷大的舍入模式。
        System.out.println(
                a+" / "+b+"="+BigDecimal.valueOf(a).divide(BigDecimal.valueOf(b),5, ROUND_FLOOR)
        );
        // ROUND_HALF_DOWN  向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。
        System.out.println(
                a+" / "+b+"="+BigDecimal.valueOf(a).divide(BigDecimal.valueOf(b),5, ROUND_HALF_DOWN  )
        );

        // ROUND_HALF_EVEN 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
        System.out.println(
                a+" / "+b+"="+BigDecimal.valueOf(a).divide(BigDecimal.valueOf(b),5, ROUND_HALF_EVEN  )
        );
        // ROUND_HALF_UP  向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
        System.out.println(
                a+" / "+b+"="+BigDecimal.valueOf(a).divide(BigDecimal.valueOf(b),5, ROUND_HALF_UP   )
        );

        // ROUND_UP   舍入远离零的舍入模式。
        System.out.println(
                a+" / "+b+"="+BigDecimal.valueOf(a).divide(BigDecimal.valueOf(b),5, ROUND_UP  )
        );

    }

}

 输出结果:

11.0 + 3.0  =  14.0
11.0 - 3.0  =  8.0
11.0 * 3.0  =  33.00
11.0 / 3.0=3.66666
11.0 / 3.0=3.66666
11.0 / 3.0=3.66667
11.0 / 3.0=3.66667
11.0 / 3.0=3.66667
11.0 / 3.0=3.66667

 

以上是关于java中的精度计算--BigDecimal的主要内容,如果未能解决你的问题,请参考以下文章

BigDecimal 高精度计算 熟悉扩展,java除法保留小数问题

金融项目java开发_BigDecimal(解决计算精度问题)

货币金额-Java中的BigDecimal

Java进行数字计算 BigDecimal计算(加减乘除)

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

BigDecimal类处理高精度计算