#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
int n = 9;
//00000000 00000000 00000000 00001001
float* pFloat = (float*)&n;
//
printf("n的值为:%d\n", n);
//9
printf("*pFloat的值为:%f\n", *pFloat);
//E=-127 *pFloat=0.000000
*pFloat = 9.0;
//0 10000010001 000 0000000 0000000000
printf("num的值为:%d\n", n);
//1091567616
printf("*pFloat的值为:%f\n", *pFloat);
//9.000000
return 0;
}
一:常⻅的浮点数:3.14159、1E10等,浮点数家族包括: float、double、long double 类型。
浮点数表⽰的范围: float.h 中定义
二:浮点数的存储
1.根据国际标准IEEE(电⽓和电⼦⼯程协会) 754,任意⼀个⼆进制浮点数V可以表⽰成下⾯的形式:
V = (−1) ∗ S M ∗ 2E
• (−1)S 表⽰符号位,当S=0,V为正数;当S=1,V为负数
• M 表⽰有效数字,M是⼤于等于1,⼩于2的
• 2
E 表⽰指数位
2.EEE 754规定:
对于32位的浮点数,最⾼的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M
对于64位的浮点数,最⾼的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字M
三:浮点数存的过程
1.EEE 754 规定,在计算机内部保存M时,默认这个数的第⼀位总是1,因此可以被舍去,只保存后⾯的xxxxxx部分。
2.,E为⼀个⽆符号整数(unsigned int)
IEEE 754规定,存⼊内存时E的真实值必须再加上
⼀个中间数,对于8位的E,这个中间数是127;对于11位的E,这个中间数是1023。
四:浮点数取的过程
三种情况:
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);

1万+

被折叠的 条评论
为什么被折叠?



