在使用BigDecimal等数据处理相关的功能时就绕不开取整的问题,取整时数据怎么舍入?这就需要指定RoundingMode来告诉它如何处理舍入问题
舍入模式
Rounding Mode | 官方解释 | 以取整为例(大白话) |
---|---|---|
UP | 远离零方向舍入的舍入模式 | 向比自己大的整数取正,俗称向上取整 |
DOWN | 向零方向舍入的舍入模式 | 舍掉小数部分直接取整数部分,俗称向下取整 |
CEILING | 向正无限大方向舍入的舍入模式 | 向上取整,跟UP一样 |
FLOOR | 向负无限大方向舍入的舍入模式 | 向下取整,但是负数的时候舍入方向跟DOWN不一样(仔细观察下面的数据实例) |
HALF_UP | 向最接近数字方向舍入的舍入模式,如果与两个相邻数字的距离相等,则向上舍入 | 就是我们最常用的四舍五入 |
HALF_DOWN | 向最接近数字方向舍入的舍入模式,如果与两个相邻数字的距离相等,则向下舍入 | 五舍六入 |
HALF_EVEN | 向最接近数字方向舍入的舍入模式,如果与两个相邻数字的距离相等,则向相邻的偶数舍入 | 四舍是肯定的,五是舍还是入需要看着办,如果五入后是偶数则五入,否则五舍(EVEN有有偶数的意思) |
数据示例:
- RoundingMode中FLOOR和DOWN有什么不一样?
当给定的数字是负数时候,负数取整的方向不一样。负数跟整数不一样,数值越大这个数越小。DOWN向上取整是向0的方向,而FLOOR向上取整是向负无穷的方向。例如:1.6这个数用DOWN向上取整就是-1,用FLOOR向上取整就是-2