BigDecimal類資料的處理和"Non-terminating decimal expansion; no exact representable decimal result"問題
阿新 • • 發佈:2019-01-28
由於需要處理精度比較高的浮點數,所以棄用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 scale, RoundingModeroundingMode) ;
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.