浮点数在内存中的存储

首先请看一段代码:

#include<stdio.h>
int main()
{
	int n = 9;
	float* pFloat = (float*)&n;
	printf("n的值为:%d\n", n);
	printf("*pFloat的值为:%f\n", *pFloat);
	*pFloat = 9.0;
	printf("num的值为:%d\n", n);
	printf("*pFloat的值为:%f\n", *pFloat);
	return 0;
}

而它的运行结果是:   

这就涉及到了浮点数在内存中的存储,接下来让我们开始对它的学习。

.任何一个二进制浮点数都可以这样表示出来:(-1)^S*M*2^E

                                              

其中,S=0时表示它是正数,S=1时表示它是个负数。M为有效数字,且1<=M<2。 

例如:V=5.5=(-1)^0*1.011*2^2。也就是S=0,M=1.011,E=2。

(注意:整数部分的5用二进制表示出来后,小数部分的5与之不同,按权重来另做划分。同时,有些小数在存储的时候,如3.3,在内存中无法精确保存,就会出现精度缺失的情况)

.对于64位的浮点数,其中S,M,E分别占1,11,52个比特位,

        而32位的浮点数中,S,M,E,分别占1,8,23个比特位。

E是可以出现负数的,存入内存时,真实值必须先加上一个中间值,8(11)个比特位的E+127(1023)。

 1.当E不全为0或不全为1时,E的计算值-127(或者是1023)得到真实值。再将有效数字M前加上第一位的1和小数点,还原得到真实值。

2.当E全为0时,E的计算值-127(或者是1023)得到真实值。有效数字M不再加上1和小数点,而是还原为0.xxxxxx的小数,这样是为了表示正负0,接近于0的很小的数字,还原得到真实值。

3.当E全为1时,这时若M全为0,表示正负无穷大(正负取决于符号位)。

三.解决代码问题

#include<stdio.h>
int main()
{
	int n = 9;
	float* pFloat = (float*)&n;
	printf("n的值为:%d\n", n);
	printf("*pFloat的值为:%f\n", *pFloat);
	*pFloat = 9.0;
	printf("num的值为:%d\n", n);
	printf("*pFloat的值为:%f\n", *pFloat);
	return 0;
}

而整数n以整型的形式打印出来为9,浮点数以浮点类型打印出来为9.000000,好理解。

新人拙作,写的不好的地方还请大家海涵并指出,感激不尽!

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值