知识回顾
在学习之前我想问大家一个问题,就是下面这个代码的运行结果是什么
int main() { int n = 9; float* pFloat = (float*)n; printf("%d", n); printf("%f", *pFloat); *pFloat = 9.0; printf("%d", n); printf("%f", *pFloat); return 0; }
怎么样,你是否能做出来呢?如果不能就请大家来复习复习前面的知识吧。
前面的学习就请大家转到这里来回顾一下https://developer.aliyun.com/article/1223088
那么这里我要补充的是当E全为0或者1的时候,我们取出来的时候又该怎么取呢?我们知道当我们在存储E的时候需要加上一个值,在32位机器上,我们需要加上127,而在64位机器上我们需要加上1023。相反的当我们拿出来的时候就需要减上一个值,当E为其他值就正常的减去就行了,可是当E为0或者1的时候,就需要不同的方法。
当E全为0时
如果还是按照常规的方式那么0-127=-127,2^-127是一个很小很小的数,它再乘上前面的数还是接近于0。所以我们就不能用常规的方法。
浮点数的指数E等于1-127或者是1-1023,而有效值的M不再加上第一位的1,而是还原成0.xxxxxx的小数。这样是为了表示+=0,以及接近于0的很小的数字。
当E全为1时
当存储的时候E全为1时,我们就可以把它看作+=无穷大,因为2^127本身就是一个相当大的数字,更不用说再乘上前面的数字,所以我们就可与把它看作是无穷大。
这些就是我补充的内容,希望能对你有所帮助