1、ROUND_UP
- 舍入远离零的舍入模式。
- 直接舍弃保留位数后面的,对保留位数的最后一位始终+1。
- 保留两位1.234 ===>1.24,1.230===>1.24
2、ROUND_DOWN
- 接近零的舍入模式。C
- 对应上一个,直接舍弃保留位数后面的,最后一位不+1。
- 保留两位1.234 ===>1.23,1.Ce230===>1.23
3、ROUND_CEILING
- 接近正无穷大的舍入模式。
- 如果 BigDecimal 为正,则舍入行为与 ROUND_UP 相同;
- 保留两位1.234 ===>1.24,1.230===>1.24
- 如果为负,则舍入行为与 ROUND_DOWN 相同。
- 保留两位-1.234 ===>-1.23,-1.230===>-1.23
4、ROUND_FLOOR
- 接近负无穷大的舍入模式。
- 如果 BigDecimal 为正,则舍入行为与 ROUND_DOWN 相同;
- 保留两位1.234 ===>1.23,1.230===>1.23
- 如果为负,则舍入行为与 ROUND_UP 相同。
- 保留两位-1.234 ===>-1.24,-1.230===>-1.24
5、ROUND_HALF_UP
- 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
- 这是我们大多数人在小学时就学过的舍入模式(四舍五入),也是我们正常理解的四舍五入模式。
6、ROUND_HALF_DOWN
- 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向下舍入的舍入模式。
- 和上面一个相反,可以理解为五舍六入。
7、ROUND_HALF_EVEN
- 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
- 此舍入模式也称为“银行家舍入法”,四舍六入,五分两种情况。
- 1.15===>1.2,1.25===>1.2
8、ROUND_UNNECESSARY
- 断言请求的操作具有精确的结果,因此不需要舍入。
- 如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。
- 使用场景较少。