double精度丢失问题

1.原理
  • 二进制的数无法表现出所有十进制的数,如十进制的0.1,在二进制中就是无限循环小数
2.例子

在这里插入图片描述

3.解决方案

<1>将乘数的小数位*10到消除然后参与计算
在这里插入图片描述
<2>使用BigDecimal类

public class test19 {
    public static void main(String[] args) {
        double d = 538.8;
        // 推荐使用string构造
        BigDecimal a1 = new BigDecimal(Double.toString(d));
        BigDecimal b1 = new BigDecimal(Double.toString(100));
        BigDecimal result = a1.multiply(b1);// 相乘结果
        System.out.println(result);
        BigDecimal one = new BigDecimal("7");
        double a = result.divide(one, 1, BigDecimal.ROUND_HALF_UP).doubleValue();//四舍五入保留1位数
        System.out.println(a);
    }
}

------------------------------------------------------------------
53880.00
7697.1
4.扩展(来源)
  • double型数据的有效位数是指它能表示的最大的十进制数字的位数。由于double型数据是用64位二进制来存储的,其中52位用来存储尾数,所以它能表示的最大的二进制数字是2^{52+1} = 9007199254740992。这个数字在十进制中有16位,所以double型数据的有效位数为15/16。第16位不一定有效,因为可能会有四舍五入或精度损失的问题。
  • 不同的例子可以是:- 1234567890123456.0和1234567890123457.0都是double型数据,但它们之间相差1,超过了第16位,所以不能被区分。- 3.141592653589793和3.141592653589794都是double型数据,但它们之间相差0.000000000000001,在第16位上有差异,所以可以被区分。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陪雨岁岁年年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值