整数和浮点数在内存中的存储

本文详细介绍了整数(源码、反码和补码)以及浮点数(根据IEEE754标准的存储结构,包括符号位、有效数字和指数位)在计算机内存中的存储方式,强调了它们的区别和取值范围限制。
摘要由CSDN通过智能技术生成

一、整数在数据中的存储

无论是什么样类型的数据,都是以二进制的方式在内存中存储,而整数在数据中存储的表现方式有三种 源码反码补码

源码反码补码这三种表现方式都分别由符号位和数值位组成,数值位中的最高位就是符号位决定了这个数据是整数还是负数,符号位里用 1 表示负数,用 0 表示正数

在正整数里,它的源码,反码和补码都相同。

在负整数里,源码:其余位置不变,符号位变为1;

                     反码:符号位不变,其他位置取反,0变1、1变0;

                     补码:符号位不变,反码+1就是补码。

对于整形来说数据的存储用的就是补码 

10000000000000000000000000000101这是-5在数据中存储的源码
11111111111111111111111111111010这是-5在数据中存储的反码,符号位不变,其余位置按位取反
11111111111111111111111111111011这是-5在数据中存储的补码,符号位不变,反码+1

而如果想从补码取得源码,只需要将补码的符号位不变,其余位置按位取反然后+1,就可以得到源码了。

以上便是整数在数据中从存储很好理解,接下来便是浮点数了。

二、浮点数在数据中的存储

1.浮点数的存储

首先在搞明白浮点数在数据中的存储之前得先要熟悉一个公式。

根据国际标准IEEE754(电气和电子协会工程),任意一个浮点数可以写成一下形式:

V = (-1)^s*M*2^E
(-1)^s
表⽰符号位,当S=0,V为正数;当S=1,V为负数
M 
表⽰有效数字,M是⼤于等于1,⼩于2的
2^E
表⽰指数位

比如 5.5 在十进制中就是 5.5,而在二进制中则是 101.1,用科学计数法表示为 1.011*2^2,由此就可以得出: (-1)^0*1.011*2^2               S = 5; M = 1.011;E = 2。

IEEE754规定:

 1. 对于32位的浮点数,最⾼的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M。

2. 对于64位的浮点数,最⾼的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字M。

图中 S  为符号位和整数一样;

M就是我们上面公式里所得到的1.011,IEEE 754 规定,在计算机内部保存M时,默认这个数的第⼀位总是1,因此可以被舍去,只保存小数点后的部分;

E就是指数位如果是二进制那E就是2科学计数法中的E是可以出现负数的,所以IEEE 754规定,存⼊内存时E的真实值必须再加上 ⼀个中间数,对于8位的E,这个中间数是127,比如,2^2的E是2,所以保存成32位浮点数时,必须保存成2+127=129。

要知道浮点数和整数在存储中可存储的大小也是有区别的,在上图里当 E 为 8 时有符号浮点数的取值范围一般为 -128 ~ 127 ,无符号浮点数的取值范围为 0 ~ 255 ;所以浮点数在内存中可能无法精确保存。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值