Java_语法基础_浮点数 近似存储

我们知道,十进制的小数部分转换成计算机的二进制存储时,采用的是乘2取整法。直到积为1为止。例如,0.8125的转换过程如下。
0.8125*2=1.625 1
0.625*2=1.25 1
0.25*2=0.5 0
0.5*2=1 1
于是,二进制的结果为0.1101,也就是1.101*2^(-1),如果以float类型变量存储该值,只需占用23位有效位数中的3位就够了,其余位为0,结果为:
0 01111110 10100000000000000000000

我们来计算下小数值0.3,过程如下。
0.3*2=0.6 0
0.6*2=1.2 1
0.2*2=0.4 0
0.4*2=0.8 0
0.8*2=1.6 1
……
乘积的结果永远不为1,这也就意味着,该小数值不能准确地用二进制来表示,就算double类型有52位有效位数,依然不能准确存储,只能在精度上比23位有效位数的float类型更接近实际值而已。这也就是浮点类型数据不能够准确存储的原因。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值