单精度浮点数和双精度浮点数存储

IEEE 754中 单精度浮点数和双精度浮点数存储

IEEE 754中 单精度浮点数和双精度浮点数存储

我们先了解一下 单精度浮点数双精度浮点数 的基本信息。

名称占用内存(bit;位)内存分配指数范围指数偏移精度
1符号位
float328指数位[-127,128]+127约7位有效数
1符号位
23尾数位
1符号位
double6411指数位[-1023,1024]+1023约16位有效数
52尾数位

单精度浮点数存储

需要32个二进制(bit)。
在这里插入图片描述

  1. Sigh(符号位)
    占最高位,其中0位整数,1为负数。

  2. Exponent(偏移的指数位)
    占30-23这8位。用于表示以2为底的指数,表示范围为[-127,128]。浮点型指数位都有一个固定的偏移量,用于是这个指数和偏移量的和为一个非负整数。(单精度浮点数的固定偏移量为127,及八位二进制全为1,八位二进制中最大数)

  3. Fraction(尾数位)
    占22-0这23位。二进制格式存储十进制浮点数时,先将十进制浮点数转换成二进制格式,之后在转化成以2为底的指数形式。

在这里插入图片描述
(尾数:指小数点放在第一位和第二位之间,并保证最高位不为0,这个处理过程叫做规范化。)

之后对尾数进行一些处理

隐藏最高位1

将最高位1和之后的小数点一起忽略,可节约一些空间。

低位补0

当经过“隐藏最高位1”这个步骤后,如果尾数不满23位时,在不影响原数据的情况下,低位补0,补满23位。

双精度浮点数存储

需要64个二进制(bit)。
在这里插入图片描述

  1. Sigh(符号位)
    占最高位,0位正数,1为负数。

  2. Exponent(偏移的指数位)
    占63-52这11位。用于表示以2为底的指数,表示范围为[-1023,1024]。浮点型指数位都有一个固定的偏移量,用于是这个指数和偏移量的和为一个非负整数。(单精度浮点数的固定偏移量为1023,及11位二进制全为1,八位二进制中最大数)

  3. Fraction(尾数位)
    占51-0这52位。二进制格式存储十进制浮点数时,先将十进制浮点数转换成二进制格式,之后在转化成以2为底的指数形式。
    在这里插入图片描述
    (尾数:指小数点放在第一位和第二位之间,并保证最高位不为0,这个处理过程叫做规范化。)

之后对尾数进行一些处理

隐藏最高位1

将最高位1和之后的小数点一起忽略,可节约一些空间。

低位补0

当经过“隐藏最高位1”这个步骤后,如果尾数不满52位时,在不影响原数据的情况下,低位补0,补满52位。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值