关于BigDecimal中divide方法中的BigDecimal.ROUND_HALF_UP和BigDecimal.ROUND_HALF_DOWN

2022-01-10 10:17:58 浏览数 (2)

大家好,今天给大家说一下BigDecimal中divide方法中的BigDecimal.ROUND_HALF_UP和BigDecimal.ROUND_HALF_DOWN。这两个类的用法其实在网上已经介绍的很多的。但是有一些注意事项还是要需要了解一下。

首先说一下用法,BigDecimal中的divide主要就是用来做除法的运算。其中有这么一个方法.

public BigDecimal divide(BigDecimal divisor,int scale, int roundingMode)

第一个参数是除数,第二个参数代表保留几位小数,第三个代表的是使用的模式。其中我们标题上就是其中的两种

BigDecimal.ROUND_DOWN:直接省略多余的小数,比如1.28如果保留1位小数,得到的就是1.2

BigDecimal.ROUND_UP:直接进位,比如1.21如果保留1位小数,得到的就是1.3

BigDecimal.ROUND_HALF_UP:四舍五入,2.35保留1位,变成2.4

BigDecimal.ROUND_HALF_DOWN:四舍五入,2.35保留1位,变成2.3

后边两种的区别就是如果保留的位数的后一位如果正好是5的时候,一个舍弃掉,一个进位。

看如下案例:

BigDecimal d1 = new BigDecimal (45); //45除以7=6.428571428571429

BigDecimal d2 = new BigDecimal (7);

d1.divide(d2,5,BigDecimal.ROUND_UP);//得到的结果就是6.42858,直接进位

但是要注意的点在这里

就是

System.out.println(d1.divide(d2,3,BigDecimal.ROUND_HALF_UP));//

System.out.println(d1.divide(d2,3,BigDecimal.ROUND_HALF_DOWN));//

上面的代码意思是结果保留3位,第四位是5,

如果我们按照上面的理解,得到的结果应该一个是6.429,一个是6.428

但是实际的运行结果都是6.429 。这里要注意,这个怎么看呢,如要注意,这两个的本质都是四舍五入,如果你的结果总位数超过了你要保留的位数,都是按照四舍五入。

那么什么时候才按照进位和设为进行运算呢,只有你的结果的位数恰好比要保留的位数多一位,并且最后一位是恰好是5,才按照之前的规则进行运算。好了,今天的分享就到这里。

0 人点赞