从db中查了一个BigDecimal数据,希望按照四舍五入的方式进行取整,发现直接使用 intValue
不太对,特此记录一下正确姿势
1 | new BigDecimal(4.51).setScale(0, RoundingMode.HALF_EVEN).intValue() |
如果我们直接使用 intValue
,会发现输出结果是直接将小数后面的扔掉了;所以这个时候需要先设置精度,然后再取整,测试如下
1 | @Test |
输出结果如下:
1 | 4 |
在上面的使用中,我们使用的RoundingMode.HALF_EVEN
这种取整模式,当然常见的四舍五入还有 HALF_UP
和 HALF_DOWN
,其中up表示为5时,向上取整;down表示为5时,向下取整;根据实际需要选择即可
II. 其他
1. 一灰灰Blog: https://liuyueyi.github.io/hexblog
一灰灰的个人博客,记录所有学习和工作中的博文,欢迎大家前去逛逛
2. 声明
尽信书则不如,已上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现bug或者有更好的建议,欢迎批评指正,不吝感激
- 微博地址: 小灰灰Blog
- QQ: 一灰灰/3302797840
3. 扫描关注
一灰灰blog
知识星球