glare II 2023-02-23 22:01 采纳率: 92.5%
浏览 25
已结题

浮点数只有十进制,那怎么在计算机中存储,计算机中不是只认二进制吗?

浮点数只有十进制,那怎么在计算机中存储,计算机中不是只认二进制吗?

  • 写回答

3条回答 默认 最新

  • 神奇的代码在哪里 2023-02-23 23:11
    关注

    用例子解释比较清楚,
    例如:
    浮点数3.0,二进制表示为011.000,也就是2+1
    浮点数0.5,二进制表示为000.100,也就是0+½,也就是0+0.5
    浮点数0.75,二进制表示为000.110,也就是0+½+¼,也就是0+0.5+0.25
    浮点数0.875,二进制表示为000.111,也就是0+½+¼+⅛,也就是0+0.5+0.25+0.125
    所以可以得出,浮点数小数部分是由一堆不断除以2的数相加组成的。

    那么问题来了,0.6怎么用二进制表示。
    经过理论论证0.6是不能用二进制完整表示的,所以计算机只能存储0.6的近似值(类似0.5999999xxxx的值)。
    也就是说浮点数在计算机中只是以二进制存储近似值,如果计算精度非常高时会出现计算出错的问题。
    参考阅读:
    https://blog.csdn.net/yy339452689/article/details/108256478

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月5日
  • 已采纳回答 2月25日
  • 创建了问题 2月23日

悬赏问题

  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上