SmileGuy17 2019-11-06 19:38 采纳率: 0%
浏览 418
已采纳

关于C语言的浮点数溢出应该怎么从二进制代码上理解?

这几天看c primer plus上写的,对于浮点数的溢出的**含义**可以理解,但是具体在**二进制代码**中的体现摸不清楚。

通常,这个操作会减小指数部分,但是假设的情况中,指数是最小值了,所以计算机只好把尾数部分的位向右移,空出1个二进制位,并丢弃最后一个二进制数。以十进制为例,把一个4位有效数字的数(如,0.1234E-10)除以10,得到的结果是0.123E-10.虽然得到了结果,但是在计算过程中却损失了原本尾有效位上的数字

对于其中的尾数部位的位向右移不是很理解,上文说空出一个二进制位,但不是规定了浮点数中哪几位是表示指数,哪几位是表示尾数部位的吗,这不是相互矛盾了吗?

还有想请问下关于浮点数的溢出如果用二进制表示出来应该是怎么样的情况?

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-11-06 21:47
    关注

    不矛盾,向右移,正因为尾数部位长度规定了几位,所以只能把最后那个数字抛弃,导致精度丢失
    比如原来是 01011001(假设是8位),向右移动应该是001011001,但是这样变成9位了,但是只能存8位,所以成为了00101100,最后那个1就没了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已采纳回答 11月6日

悬赏问题

  • ¥500 高有偿提问!求优化设计微信小程序
  • ¥15 matlab在安装时报错 无法找到入口 无法定位程序输入点
  • ¥15 收益高的广告联盟有哪些
  • ¥15 Android Studio webview 的使用问题, 播放器横屏全屏
  • ¥15 删掉jdk后重新下载,Java web所需要的eclipse无法使用
  • ¥15 uniapp正式环境中通过webapi将本地数据推送到设备出现的跨域问题
  • ¥15 xui建立节点,显示错误
  • ¥15 关于#单片机#的问题:开始、复位、十进制的功能可以实现,但是切换八进制的功能无法实现(按下按键也没有效果),把初始状态调成八进制,也是八进制可以实现但是切换到十进制不行(相关搜索:汇编语言|计数器)
  • ¥15 VINS-Mono或Fusion中feature_manager中estimated_depth是特征的深度还是逆深度?
  • ¥15 谷歌浏览器如何备份抖音网页数据