1. 程式人生 > >BigDecimal類資料的處理和"Non-terminating decimal expansion; no exact representable decimal result"問題

BigDecimal類資料的處理和"Non-terminating decimal expansion; no exact representable decimal result"問題

由於需要處理精度比較高的浮點數,所以棄用double型別,改用BigDecimal類來進行數值處理。

在加減乘時都沒有出現問題,但是到除法運算時,提示瞭如下錯誤:

(Non-terminating decimal expansion; no exact representable decimal result)

大概的意思是“無法結束的除法表示式;沒有精確的除結果”。我當時輸入的10/3,結果應該是3.3333....333。

於是在網上找資料,發現我原來的處理方式有問題。

BigDecimal num1 = new BigDecimal("10");
BigDecimal num2 = new BigDecimal("3");
BigDecimal num3 = num1.divide(num2);

其實devide的函式定義如下

BigDecimal.divide(BigDecimal divisor, int scaleRoundingModeroundingMode) ;

scale為小數位數;

roundingMode為小數模式,模式如下:

ROUND_CEILING
如果 BigDecimal 是正的,則做 ROUND_UP 操作;如果為負,則做 ROUND_DOWN 操作。
ROUND_DOWN
從不在捨棄(即截斷)的小數之前增加數字。
ROUND_FLOOR
如果 BigDecimal 為正,則作 ROUND_UP ;如果為負,則作 ROUND_DOWN 。
ROUND_HALF_DOWN

若捨棄部分> .5,則作 ROUND_UP;否則,作 ROUND_DOWN 。
ROUND_HALF_EVEN
如果捨棄部分左邊的數字為奇數,則作 ROUND_HALF_UP ;如果它為偶數,則作 ROUND_HALF_DOWN 。
ROUND_HALF_UP
若捨棄部分>=.5,則作 ROUND_UP ;否則,作 ROUND_DOWN 。
ROUND_UNNECESSARY
該“偽舍入模式”實際是指明所要求的操作必須是精確的,,因此不需要舍入操作。
ROUND_UP
總是在非 0 捨棄小數(即截斷)之前增加數字。

寫成如下便可通過

BigDecimal num3 = num1.divide(num2,10,RoundingMode.

ROUND_CEILING);