双精度计算不准

  最近在做一个金融行业的项目,之前少有项目与金额计算打交道,所以对金额的计算不以为然,使用java的Double进行加减乘除。但是实际做计算却发现计算精度会丢失。接着搜索大家推荐BigDecimal。

  使用BigDecimal发现,依然有坑。只能使用BigDecimal的字符串构造对象才能正确计算。不多说,上干货。

 

BigDecimal b1 = new BigDecimal(80.96d);
BigDecimal b2 = new BigDecimal(100d);
System.out.println(b1.multiply(b2).doubleValue());

计算结果为:8095.999999999999 。我们期望的结果是 8096.0

 

而使用BigDecimal的String构造,则成功

BigDecimal b1 = new BigDecimal(Double.toString(80.96d));
BigDecimal b2 = new BigDecimal(Double.toString(100d));
System.out.println(b1.multiply(b2).doubleValue());

计算结果: 8096.0


转载于:https://my.oschina.net/u/1983430/blog/479748

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值