使用MathContext调用时,BigDecimal.divide()会产生额外的精度数字

200*_*ess 4 java precision bigdecimal arbitrary-precision

鉴于简单的计划

import java.math.*;
import static java.math.BigDecimal.ONE;
import static java.lang.System.out;

public static void main(String[] args) {
    StringBuffer ruler = new StringBuffer("  ");
    for (int i = 0; i < 5; i++) {
         ruler.append("1234567890");
    }

    out.println(ONE.divide(new BigDecimal(47), 50, RoundingMode.HALF_UP));
    out.println(ONE.divide(new BigDecimal(47), new MathContext(50, RoundingMode.HALF_UP)));
    out.println(ruler);
    out.println(ONE.divide(new BigDecimal(6), 5, RoundingMode.HALF_UP));
    out.println(ONE.divide(new BigDecimal(6), new MathContext(5, RoundingMode.HALF_UP)));
}
Run Code Online (Sandbox Code Playgroud)

这是输出:

0.02127659574468085106382978723404255319148936170213
0.021276595744680851063829787234042553191489361702128
  12345678901234567890123456789012345678901234567890
0.16667
0.16667
Run Code Online (Sandbox Code Playgroud)

我希望第二行输出与第一行相同.这是一个错误,还是我误解了BigDecimal文档?

JVM版本:

$ java -version
java version "1.7.0_45"
Java(TM) SE Runtime Environment (build 1.7.0_45-b18)
Java HotSpot(TM) 64-Bit Server VM (build 24.45-b08, mixed mode)
Run Code Online (Sandbox Code Playgroud)

Daw*_*ica 5

您有缩放比例(小数位总数)与精度(有效位数).对于介于-1和1之间的数字,精度不计算小数点和非零小数位之间的任何零,但是标度确实如此.

第二个参数BigDecimal.divide是一个比例.所以你的第一个输出得到50位小数.

MathContext构造函数的参数是精度.因此,对于第二个输出,您将获得50个有效小数位,以及小数点和2之间的一个额外零.

  First decimal place (start counting scale from here)
  ?
0.02127659574468085106382978723
   ?
   First significant digit (start counting precision from here)
Run Code Online (Sandbox Code Playgroud)