網(wǎng)上隨便一搜弹沽,是這么寫的:
ROUND_CEILING
Rounding mode to round towards positive infinity.
向正無窮方向舍入
ROUND_DOWN
Rounding mode to round towards zero.
向零方向舍入
ROUND_FLOOR
Rounding mode to round towards negative infinity.
向負無窮方向舍入
ROUND_HALF_DOWN
Rounding mode to round towards "nearest neighbor" unless both neighbors are equidistant, in which case round down.
向(距離)最近的一邊舍入筷频,除非兩邊(的距離)是相等,如果是這樣,向下舍入, 例如1.55 保留一位小數(shù)結(jié)果為1.5
ROUND_HALF_EVEN
Rounding mode to round towards the "nearest neighbor" unless both neighbors are equidistant, in which case, round towards the even neighbor.
向(距離)最近的一邊舍入芭析,除非兩邊(的距離)是相等,如果是這樣,如果保留位數(shù)是奇數(shù)吞瞪,使用ROUND_HALF_UP 馁启,如果是偶數(shù),使用ROUND_HALF_DOWN
ROUND_HALF_UP
Rounding mode to round towards "nearest neighbor" unless both neighbors are equidistant, in which case round up.
向(距離)最近的一邊舍入,除非兩邊(的距離)是相等,如果是這樣惯疙,向上舍入, 1.55保留一位小數(shù)結(jié)果為1.6
ROUND_UNNECESSARY
Rounding mode to assert that the requested operation has an exact result, hence no rounding is necessary.
計算結(jié)果是精確的翠勉,不需要舍入模式
ROUND_UP
Rounding mode to round away from zero.
向遠離0的方向舍入
MathContext mathContext = new MathContext(2,RoundingMode.UP);
BigDecimal test1 = BigDecimal.valueOf(19785.076);
BigDecimal test2 = BigDecimal.valueOf(100.0d);
LogUtil.i("result="+test1.divide(test2,mathContext).doubleValue());
結(jié)果是多少?
200.0
奇怪了霉颠,為什么是200.0对碌?其實我的目的是想結(jié)果為:197.86。因為我是這么想的:保留2位小數(shù)蒿偎,然后小數(shù)的2位之后如果還有數(shù)(也就是說后面的大于0)朽们,那么會進1位。
但結(jié)果就是200.0诉位,后來查了一下那MathContext里面的2并不是指保留2位小數(shù)骑脱,而是指的有效位數(shù)。所以BigDecimal.divide(BigDecimical,MathContext)就不能用了苍糠。直接用BigDecimal.divide(BigDecimaldivisor,RoundingModeroundingMode).setScale(intnewScale,RoundingModeroundingMode)來解決問題惜姐。
但是,直接用BigDecimal.divide(BigDecimaldivisor,RoundingModeroundingMode)那么它是保留幾位呢椿息?懶得看源碼歹袁,簡單測試了一下,結(jié)果是:
eg1:
BigDecimal test1 = BigDecimal.valueOf(19785.076);
BigDecimal test2 = BigDecimal.valueOf(100.0d);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:197.851
eg2:
BigDecimal test1 = BigDecimal.valueOf(19785.070);
BigDecimal test2 = BigDecimal.valueOf(100.0d);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:197.86
eg3:
BigDecimal test1 = BigDecimal.valueOf(19785.006);
BigDecimal test2 = BigDecimal.valueOf(100.0d);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:197.851
eg4:
BigDecimal test1 = BigDecimal.valueOf(19785.06);
BigDecimal test2 = BigDecimal.valueOf(100.0d);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:197.86
eg5:
BigDecimal test1 = BigDecimal.valueOf(19785.1);
BigDecimal test2 = BigDecimal.valueOf(100.0d);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:197.9
eg6:
BigDecimal test1 = BigDecimal.valueOf(19785);
BigDecimal test2 = BigDecimal.valueOf(100.0d);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:198.0
eg7:
BigDecimal test1 = BigDecimal.valueOf(19785);
BigDecimal test2 = BigDecimal.valueOf(100);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:198.0
eg8:
BigDecimal test1 = BigDecimal.valueOf(19785);
BigDecimal test2 = BigDecimal.valueOf(100.01);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:198.0
eg9:
BigDecimal test1 = BigDecimal.valueOf(19785);
BigDecimal test2 = BigDecimal.valueOf(100.11);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:198.0
eg10:
BigDecimal test1 = BigDecimal.valueOf(19785);
BigDecimal test2 = BigDecimal.valueOf(100.91);
LogUtil.i("result="+test1.divide(test2,RoundingMode.UP).doubleValue());//輸出:197.0
發(fā)現(xiàn)規(guī)律了嗎寝优?
RoundingMode:
1条舔、除數(shù)的小數(shù)點位數(shù)與結(jié)果的位數(shù)直接相關(guān)聯(lián),而被除數(shù)的小數(shù)點位數(shù)與結(jié)果的位數(shù)沒有啥關(guān)系(至少簡單測試一下看上去是這樣)乏矾,但是被除數(shù)的小數(shù)位數(shù)不是說沒有用孟抗,而是對結(jié)果與直接關(guān)聯(lián)。
2钻心、除數(shù)如果是N位小數(shù)凄硼,那么結(jié)果就會是N位小數(shù)。但有2個例外:
①除數(shù)如果沒有小數(shù)捷沸,在BigDecimal后面再繼續(xù)用doubleValue會發(fā)現(xiàn)有xxx.0出現(xiàn)摊沉;
②除數(shù)的最后1位如果為0,那么就會被忽略痒给。如上eg2與eg3说墨。
先不寫了。反正就沒打算給別人看的苍柏,自己記錄一下就OK了尼斧,所以也沒啥排版,知識也不夠全面试吁。