BigDecima類型數據的處理--Non-terminating decimal expansio

異常提示:
  Non-terminating decimal expansion; no exact representable decimal result
備註:在加減乘時都沒有出現問題,可是到除法運算時異常;
一個無限循環小數,沒有精確可表示的結果
方法:四捨五入模式,將一個無限循環小數進行四捨五入ide

解決方案:
一:multiply求百分比
            BigDecimal brokerage=financeStatisticDto.getTotalWinLossGold().multiply(new BigDecimal(financeStatisticDto.getSelltement())).dive(new BigDecimal(100) );

二:divde求百分比
             BigDecimal winLo***ate=finaceStatisticDto.getTotalWinLossGlod().divide(financeStaticDto.getTotalOrderGold(),2,RoundingMode.CEILING).multiply(new BigDecimal(100));

三: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 num = num1.divide(num2,10,RoundingMode.ROUND_CEILING);code

相關文章
相關標籤/搜索