深入理解BigDecimal

为什么要使用BigDecimal? 

我想只要是从事过JAVA金融产品研发工作的同学对于BigDecimal就一定不会陌生。但同学们是否想过为什么要用BigDecimal数据类型,是否可以直接使用单精度或者双精浮点数来表示金额信息?答案肯定是不可以的,用一句话来解释就是:十进制的小数在转化成二进制浮点数时会产生精度问题,例如:0.3转化成二进制(转化方法自行问百度)。

BigDecimal的底层数据结构使什么?它是怎么保证精度的?

这曾经是一道阿里巴巴的面试题,由于在工作中使用最多的是BigDecimal的加、减、乘、除的的方法,还真没想过它的实现原理(完全是拿来主义惹的祸),乍这么一问还真有点懵。BigDecimal保证精度的解决思路其实极其的简单朴素,还是用一句话来解释:十进制整数在转化成二进制数时不会有精度问题,那么把十进制小数扩大N倍让它在整数的维度上进行计算,并保留相应的精度信息

请大家注意

MySql中的统计函数:sum()、avg()等等,给JAVA应用默认返回的是Double类型!在处理小数的时候可能产生精度问题,此时把预处理的字段数据用cast强转成decimal类型,那么MySql给JAVA应用返回的就是BigDecimal类型。

 

  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
在Java中,BigDecimal类提供了减法操作,可以用于准确地执行浮点数的减法运算。你可以使用subtract方法来执行减法操作。例如,要计算两个BigDecimal对象的差值,可以使用subtract方法,如下所示: BigDecimal result = bigDecimal1.subtract(bigDecimal2); 其中,bigDecimal1和bigDecimal2是要进行减法运算的两个BigDecimal对象,result是保存结果的BigDecimal对象。 需要注意的是,BigDecimal的减法操作返回的是一个新的BigDecimal对象,而不会修改原始的BigDecimal对象。另外,在进行减法运算时,需要确保使用的BigDecimal对象已经设置了正确的精度和舍入模式。可以使用setScale方法设置精度,并使用setRoundingMode方法设置舍入模式。 在使用BigDecimal进行减法运算时,还需要注意处理除不尽的情况。如果除法运算的结果无法整除,可以使用divide方法的重载版本,指定精度和舍入模式来处理除不尽的情况。例如,可以使用以下方法执行除法运算并保留两位小数,并使用四舍五入的方式处理除不尽的情况: BigDecimal result = bigDecimal1.divide(bigDecimal2, 2, BigDecimal.ROUND_HALF_UP); 总结起来,使用BigDecimal进行减法运算需要以下步骤: 1. 使用subtract方法执行减法运算,得到一个新的BigDecimal对象。 2. 如果需要处理除不尽的情况,可以使用divide方法的重载版本,并指定精度和舍入模式来执行除法运算。 3. 使用setScale方法设置结果的精度。 4. 使用setRoundingMode方法设置结果的舍入模式。 综上所述,以上是使用BigDecimal进行减法运算的方法和注意事项。希望对你有帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [BigDecimal](https://download.csdn.net/download/weixin_38733597/14033762)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [深入理解 BigDecimal 的使用](https://blog.csdn.net/ncut_LJD/article/details/103501233)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值