BigDecimal.setScale 处理java小数点
生活随笔
收集整理的這篇文章主要介紹了
BigDecimal.setScale 处理java小数点
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
BigDecimal.setScale()方法用于格式化小數點
setScale(1)表示保留一位小數,默認用四舍五入方式
setScale(1,BigDecimal.ROUND_DOWN)直接刪除多余的小數位,如2.35會變成2.3
setScale(1,BigDecimal.ROUND_UP)進位處理,2.35變成2.4
setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35變成2.4 setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35變成2.3,如果是5則向下舍 注釋: 1: scale指的是你小數點后的位數。比如123.456則score就是3.
score()就是BigDecimal類中的方法啊。
比如:BigDecimal b = new BigDecimal("123.456"); b.scale(),返回的就是3.
2:
roundingMode是小數的保留模式。它們都是BigDecimal中的常量字段,有很多種。
比如:BigDecimal.ROUND_HALF_UP表示的就是4舍5入。
3:
pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
的意思是說:我用一個BigDecimal對象除以divisor后的結果,并且要求這個結果保留有scale個小數位,roundingMode表示的就是保留模式是什么,是四舍五入啊還是其它的,你可以自己選!
System.out.println("mData=" + mData); ----結果:----- mData=9.66 http://hi.baidu.com/hsyl/blog/item/5a690df4b546a6e57709d7a5.html
setScale(1)表示保留一位小數,默認用四舍五入方式
setScale(1,BigDecimal.ROUND_DOWN)直接刪除多余的小數位,如2.35會變成2.3
setScale(1,BigDecimal.ROUND_UP)進位處理,2.35變成2.4
setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35變成2.4 setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35變成2.3,如果是5則向下舍 注釋: 1: scale指的是你小數點后的位數。比如123.456則score就是3.
score()就是BigDecimal類中的方法啊。
比如:BigDecimal b = new BigDecimal("123.456"); b.scale(),返回的就是3.
2:
roundingMode是小數的保留模式。它們都是BigDecimal中的常量字段,有很多種。
比如:BigDecimal.ROUND_HALF_UP表示的就是4舍5入。
3:
pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
的意思是說:我用一個BigDecimal對象除以divisor后的結果,并且要求這個結果保留有scale個小數位,roundingMode表示的就是保留模式是什么,是四舍五入啊還是其它的,你可以自己選!
4:對于一般add、subtract、multiply方法的小數位格式化如下:
BigDecimal mData = new BigDecimal("9.655").setScale(2, BigDecimal.ROUND_HALF_UP);System.out.println("mData=" + mData); ----結果:----- mData=9.66 http://hi.baidu.com/hsyl/blog/item/5a690df4b546a6e57709d7a5.html
轉載于:https://www.cnblogs.com/liuzhuqing/p/7480193.html
總結
以上是生活随笔為你收集整理的BigDecimal.setScale 处理java小数点的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SQL之存储过程详细介绍及语法(转)
- 下一篇: YARN构建--解决cypress下载慢