網(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.
向負(fù)無窮方向舍入
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.
計(jì)算結(jié)果是精確的,不需要舍入模式
ROUND_UP
Rounding mode to round away from zero.
向遠(yuǎn)離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?其實(shí)我的目的是想結(jié)果為:197.86。因?yàn)槲沂沁@么想的:保留2位小數(shù),然后小數(shù)的2位之后如果還有數(shù)(也就是說后面的大于0),那么會(huì)進(jìn)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ù)點(diǎn)位數(shù)與結(jié)果的位數(shù)直接相關(guān)聯(lián),而被除數(shù)的小數(shù)點(diǎn)位數(shù)與結(jié)果的位數(shù)沒有啥關(guān)系(至少簡單測試一下看上去是這樣),但是被除數(shù)的小數(shù)位數(shù)不是說沒有用,而是對(duì)結(jié)果與直接關(guān)聯(lián)。
2、除數(shù)如果是N位小數(shù),那么結(jié)果就會(huì)是N位小數(shù)。但有2個(gè)例外:
①除數(shù)如果沒有小數(shù),在BigDecimal后面再繼續(xù)用doubleValue會(huì)發(fā)現(xiàn)有xxx.0出現(xiàn);
②除數(shù)的最后1位如果為0,那么就會(huì)被忽略。如上eg2與eg3。
先不寫了。反正就沒打算給別人看的,自己記錄一下就OK了,所以也沒啥排版,知識(shí)也不夠全面。