由于需要處理精度比較高的浮點數,是以棄用double類型,改用BigDecimal類來進行數值處理。
在加減乘時都沒有出現問題,但是到除法運算時,提示了如下錯誤:
大概的意思是“無法結束的除法表達式;沒有精确的除結果”。我當時輸入的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, RoundingMode roundingMode) ;
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,BigDecimal.ROUND_HALF_DOWN);