Java BigDecimal:如何仅在比例大于某个精度点时才设置比例?



我有一个用例,仅当数字的精度大于某些数字时,我只想设置比例。换句话说,如果精度为5,我想将比例设置为4

这是我期望的预期结果 ->

123.123 => 123.123->留下数字,因为精度小于4。

123.123456 => 123.1235->设置了比例,并舍入。

123 => 123->留下数字,因为精度小于4。

0.1234445 => 0.1234->设置了比例,然后舍入。

如何使用Java的bigdecimal?

实现此结果

看来您真正问的问题是"我如何截断大二十进制的小数部分,以便它最多在小数点的右边有4个数字?" <<

首先,我认为您应该确保您了解scaleprecisionBigDecimal中意味着什么。

如果您运行了这个小程序:

public static void main(String[] args) {
    List<BigDecimal> decimals = new LinkedList<>();
    decimals.add( new BigDecimal(".123456"));
    decimals.add( new BigDecimal("1.23456"));
    decimals.add( new BigDecimal("12.3456"));
    decimals.add( new BigDecimal("123.456"));
    decimals.add( new BigDecimal("1234.56"));
    decimals.add( new BigDecimal("12345.6"));
    decimals.add( new BigDecimal("123456"));
    for(BigDecimal bd : decimals){
        System.out.println(bd.toPlainString() + ". scale = " + bd.scale() + ", precision = " + bd.precision());
    }
}

您会看到以下输出:

0.123456. scale = 6, precision = 6 
1.23456. scale = 5, precision = 6
12.3456. scale = 4, precision = 6
123.456. scale = 3, precision = 6
1234.56. scale = 2, precision = 6
12345.6. scale = 1, precision = 6
123456. scale = 0, precision = 6

您现在应该看到您想做的是查询,然后调整数字的scale

static BigDecimal doIt(BigDecimal input){
    if(input.scale() > 4){
        return input.setScale(4, RoundingMode.HALF_DOWN);
    }
    else{
        return input;
    }
}

一个小测试程序显示输出是您要求的:

public static void main(String[] args) {
    List<BigDecimal> decimals = new LinkedList<>();
    decimals.add(new BigDecimal("123.123"));
    decimals.add(new BigDecimal("123.123456"));
    decimals.add(new BigDecimal("123"));
    decimals.add(new BigDecimal("0.1234445"));

    for (BigDecimal bd : decimals) {
        System.out.println(bd.toPlainString() + " ---> " + doIt(bd));
    }
}

输出

123.123 ---> 123.123
123.123456 ---> 123.1235
123 ---> 123
0.1234445 ---> 0.1234

这些属性具有访问方法,您可以直接测试它们:

public static void setScaleIfNeeded(BigDecimal bd, int scale, int minPrecision) {
    if (bd.precision() >= minPrecision) {
        bd.setScale(scale);
    }
}

最新更新