那些年我们踩过的坑-BigDecimal精度丢失的问题

一般java需要对有小数点数字进行计算的时候都是推荐使用BigDecimal因为用这个来计算不会出现精度丢失的问题 可是如果使用不当 BigDecimal其实也会有精度丢失的风险下面的代码打印出来的结果可以猜猜是多少BigDecimal decimal = new BigDecimal(122.11);System.out.println(decimal.toString());//打印...
摘要由CSDN通过智能技术生成

一般java需要对有小数点数字进行计算的时候都是推荐使用BigDecimal因为用这个来计算不会出现精度丢失的问题 可是如果使用不当 BigDecimal其实也会有精度丢失的风险
下面的代码打印出来的结果可以猜猜是多少

BigDecimal decimal = new BigDecimal(122.11);
System.out.println(decimal.toString());
//打印结果
122.1099999999999994315658113919198513031005859375

可以看到结果不是122.11 这时候如果把decimal结果进行计算 是有问题的
想要进度不丢失 可以把122.11数字变成字符串

BigDecimal decimal = new BigDecimal("122.11");
System.out.println(decimal.toString());
//正常结果
122.11

之所以会这样 主要是因为BigDecimal字符串和双精度类型的构造函数里执行的代码不同
下面是BigDecimal双精度类型的构造代码

public BigDecimal(double val) {
    long valBits = Double.doubleToLongBits(val);
}
public static long doubleToLongBits(double value) {
   long result = doubleToRawLongBits(value);
   if ( ((result & DoubleConsts.EXP_BIT_MASK) ==
         DoubleConsts.EXP_BIT_MASK) &&
        (result & DoubleConsts.SIGNIF_BIT_MASK) != 0L)
       result = 0x7ff800000
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值