【C语言】浮点型在内存中的存储

1. 摘要

在了解到C语言中整型是以二进制补码形式存储在内存中后,我们不禁很好奇:那么浮点型的数据是以什么形式存储在内存中的呢?

实际上,早在1985年,电气电子工程师学会就制定了IEEE 754标准来解决单精度浮点数在计算机内存中的存储问题。

那么接下来,我们就以IEEE754-1985版来看一看浮点数在内存中的真实面目。

2. 浮点数的表达方式

2.1 浮点数的组成

浮点型家族中包含有:float、double、long double类型

IEEE 754标准下,一个浮点数V可以被拆解成三个部分

V = (-1) ^ S * f * 2 ^ E
  1. 1-bit sign S ------ 符号位S,用来表示正负
  2. Biased exponent e = E+bias:指数位,负责浮点数的大小
  3. Fraction f = · b1b2 … bp−1:小数位,负责浮点数的精度,且f大于等于1小于2

2.2 单精度浮点数

对于32位的单精度浮点数而言,内存中32个bit位是这样分配的:

  1. 1位符号位
  2. 8位指数位
  3. 23位小数位

在这里插入图片描述

2.3 双精度浮点数

对于64位的双精度浮点数而言,内存中64个bit位是这样分配的:

  1. 1位符号位
  2. 11位指数位
  3. 52位小数位
    在这里插入图片描述

2.4 指数偏差(Biased Exponent)

2.4.1指数E不为全0或全1

对于float型,我们发现8位的E如果就表示8个无符号的二进制位,那么指数位2^E只能表示比1大的数,

  • 24
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 13
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

DanteIoVeYou

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

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

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

打赏作者

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

抵扣说明:

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

余额充值