浮点数在内存中的表示方式

 

今天群里面的朋友提了一个问题,float在内存中是如何表示的。这看似一个很简单的问题,但我确一时不知道该怎么表示。忘得不能再忘了,看到别人写了一个很好的文章,Ctrl+C过来慢慢体会!

 

根据IEEE的标准,浮点数的定义如下

 

我们以单精度浮点数来说明:
符号位,表述浮点数的正或者负
指数实际也有正负的,但是没有单独的符号位,而是采用了一个偏移来表示
在计算机的世界里,进位都是二进制的,指数表示的也是2的N次幂
这个数据格式当中的,指数是8位,可表达的范围是0到255
而对应的实际的指数是-127到+128
这里特殊说明,-127和+128这两个数据在IEEE当中是保留的用作多种用途的
-127表示的数字是0
128和其他位数组合表示多种意义,最典型的就是NAN状态

小数部分,并不是一个浮点数的实际的小数
实际的小数在这个小数前面还保留了一个1
拿浮点数1.0来说
符号位是0, 实际指数是0,对应这里的指数就是127了,也就是0x7f
而小数部分就是1.0了, 1是暗含的不存储,实际的小数部分就是0了
因此组合起来的数据就是,0x3f80000

 

 

234.0用float类型表示时使用4字节保存,内容是 0x436a0000。

换成二进制表示为0 10000110 11010100000000000000000,

其中符号为0,指数为10000110,有效数字为11010100000000000000000。

指数换成10进制为134,减去127为7。

有效数字其实是小数部分,加上省略的整数部分1为 1.110101,将小数点向右移7位就相当于乘以2的指数次幂,

即11101010,换成10进制为234。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值