必威体育Betway必威体育官网
当前位置:首页 > IT技术

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

时间:2019-06-02 23:43:04来源:IT技术作者:seo实验室小编阅读:57次「手机版」
 

bigdecimal.divide

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

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

public BigDecimal pide(BigDecimal pisor,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.pide(d2,5,BigDecimal.ROUND_UP);//得到的结果就是6.42858,直接进位

但是要注意的点在这里

就是

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

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

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

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

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

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

好了关于配置环境变量的问题我们就探讨到这里,如果大家有其他疑问,可在文章下留言,如果觉得文章对自己的学习有帮助,请关注我的博客,后面会有更多的文章发布。也可以添加qq群:767375013。里边有更多的文档视频资料,及线上免费公开课。希望和大家一起探讨。想学java的同学,也可以看我的java基础教学视频https://www.bilibili.com/video/av37413483?from=search&seid=16996396768466285203,免费学习

  

相关阅读

java BigDecimal类型 比较大小

一般我们进行类型比较有.equals()、==、.compareTo()但是当比较bigdecimal类型时最好使用.compareTo()来比较大小BigDecimal a=Bi

BigDecimal的divide方法报错

报错: java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result. 报错

BigDecimal格式比较大小

与0比较大小int t = big_decimal.compareTo(BigDecimal.ZERO);if(t==0) //等于if(t==1) //大于if(t==-1) //小于

BigDecimal的加减乘除以及比较大小和取最大最小值

BigDecimal num1 = new BigDecimal("100"); 6 BigDecimal num2 = new BigDecimal("50"); 7

BigDecimal 精度问题

今天在做一个需求,遇到了一点问题,模拟代码如下:// 小计 BigDecimal subtotal = new BigDecimal(1000000); // 变更后数量 BigDecima

分享到:

栏目导航

推荐阅读

热门阅读