支付系统中BigDecimal使用中的问题

支付系统中财务相关数据类型使用BigDecimal,比如支付宝、微信的费率,实际使用过程我们可能会出现部分退费的场景,通过退费数据比例获取部分退费的费率,会通过获取数据精度的方式拿到大致准确的费率

// 0.9067 通过退款金额和支付金额计算出来的比例
BigDecimal refundRate = new BigDecimal(0.9067);
// 计算出来的退款比例乘以费率3%,获取四位精度,保留2位精度数据
long value = refundRate.multiply(new BigDecimal(3)).setScale(2, BigDecimal.ROUND_HALF_UP).longValue();

refundRate.multiply(new BigDecimal(3)).setScale(2, BigDecimal.ROUND_HALF_UP)

计算出来的结果是2.99,取longValue()得到2,和实际费率3区别很大,没有实际上做四舍五入

修改后的代码如下:

// 0.9067 通过退款金额和支付金额计算出来的比例
BigDecimal refundRate = new BigDecimal(0.9067);
// 计算出来的退款比例乘以费率3%,获取四位精度,保留0位精度数据
long value = refundRate.multiply(new BigDecimal(3)).setScale(0, BigDecimal.ROUND_HALF_UP).longValue();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值