浮点型在内存中的存储

浮点型在内存中的存储

浮点型包括float、double、long doule。



前言

在内存存储中,整形与浮点型存储方式不同。

#define _CRT_SECURE_NO_WARNINGS 
#include <stdio.h>

int main()
{
	int n = 1;
	float* p = (float*)&n;                //将其强制类型转换为float*
	printf("n的值为:%d\n", n);
	printf("*p的值为:%f\n", *p);

	*p = 1.0;
	printf("n的值为:%d\n", n);
	printf("*p的值为:%f\n", *p);
	return 0;
}

在这里插入图片描述
由图可以看出,两种类型转换后的结果出现差异,可以知道整形和浮点型在内存中的存储方式不同。


一、浮点型在内存中的取值范围

在C语言中,其取值范围的查询可以在float.h中查到。
在这里插入图片描述
在图上可以看出,在查阅float.h头文件后,从上至下红框依次为double的精度、最大取值、最小取值;float的精度、精度值、最大取值、最小取值。

二、存储规则

整数在内存中存储方法为反码,而浮点数的存储方法根据国际标准IEEE(电气和电子工程协会) 754,任意一个二进制浮点数V可以表示成下面的形式。

  • (-1)^S * M * 2^E
  • (-1)^s表示符号位,当s=0,V为正数;当s=1,V为负数。
  • M表示有效数字,大于等于1,小于2。
  • 2^E表示指数位。

在此假设某一浮点型为11.0
将其按照小数点前和小数点后分别化为二进制形式为:1011.0
其用上述规则表示为(-1)0 × 1.011×23
就可确定上述规则中的三个值,S为0,M为1.011,E为3。

对于浮点数的存储,只要将其S、M、E进行存储,就可以还原出浮点数的存储。
对于32位的单精度浮点数存储模型,其最高的1位为符号位S,紧接着的8位为指数E,剩下的23位为有效数字M。
对于64位的单精度浮点数存储模型,其最高的1位为符号位S,紧接着的11位为指数E,剩下的52位为有效数字M。

2.1 对于M

由于M的取值为1≤M<2,故M的个位总为1,故而为提高精度,有效数字的M在内存中仅仅存储小数点后的二进制位。

2.2 对于指数E的存储

E为一个无符号整数,如果E为8位,它的取值范围为0-255;如果E为11位,它的取值范围为0-2047。但是,科学计数法中的E是可以出现负数的,所以规定,存入内存时E的真实值必须再加上一个中间数,对于8位的E,这个中间数是127;对于11位的E,这个中间数是1023。比如,2-1的E是-1,所以保存成32位浮点数时,必须保存成-1+127=126,即0111 1110。

2.3 指数E从内存中取出

1、E不全为0或不全为1
指数E的计算值减去127(或1023),得到真实值,再将有效数字M前加上第一位的1。
2、E全为0
浮点数的指数E等于1-127(或者1-1023)即为真实值。
有效数字M不再加上第一位的1,而是还原为0.xxxxxx的小数。这样做是为了表示±0,以及接近于0的很小的数字。
3、E全为1
如果有效数字M全为0,表示±无穷大(正负取决于符号位s)。

总结

本篇博客介绍了浮点型在内存中的存储规则,利用C语言进行相关讲解。

浮点型数据在内存存储方式是按照IEEE 754标准进行存储的。IEEE 754标准规定了两种浮点数的表示方法:单精度浮点数和双精度浮点数。其,单精度浮点数占用4个字节,双精度浮点数占用8个字节。 在IEEE 754标准,浮点数的存储格式由三部分组成:符号位、指数位和尾数位。其,符号位用来表示浮点数的正负,指数位用来表示浮点数的数量级,尾数位用来表示浮点数的精度。 具体来说,单精度浮点数的存储格式如下所示: | 31 | 30 - 23 | 22 - 0 | |----|---------|--------| | S | E | M | 其,S表示符号位,占用1个bit;E表示指数位,占用8个bit;M表示尾数位,占用23个bit。双精度浮点数的存储格式类似,只是指数位和尾数位的长度不同。 在计算机,浮点数的存储方式是按照二进制补码进行存储的。具体来说,符号位用0表示正数,用1表示负数;指数位和尾数位都用二进制补码表示。 举个例子,如果要将3.14这个单精度浮点数存储到计算机,首先需要将3.14转换成二进制数。具体来说,可以使用以下方法进行转换: 3.14 = 11.0010001111...(二进制) 然后,根据IEEE 754标准的规定,将上述二进制数按照符号位、指数位和尾数位的顺序存储到计算机。具体来说,可以将上述二进制数转换成以下形式: | 0 | 10000000 | 10001100100011110101110 | |---|----------|------------------------| | S | E | M | 其,符号位S为0,表示正数;指数位E为10000000,表示指数为128(因为E需要加上一个固定的偏移量127,才能表示实际的指数值);尾数位M为10001100100011110101110,表示尾数为1.5707964(因为M需要除以2的23次方,才能表示实际的尾数值)。 因此,3.14这个单精度浮点数在计算机存储方式为: 01000000000100110010001111010111
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值