网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
大家好,我是纪宁。
这篇博客将给大家介绍浮点数在内存中是如何进行计算的
浮点数的二进制转化及存储规则等
在上次介绍了数据在内存中是如何存储的,其中就介绍了浮点数是如何在内存中存储的
不懂浮点数的二进制是如何转化和存储的可以去看我的这篇博客
其中详细介绍了浮点数的二进制如何转化以及国际标准IEEE规定的浮点数在内存中的存储方法
以下为简单复习
一个浮点数可以统一写成 (-1)^S * M * 2E,其中**(-1)S表示这个浮点数的正负**,当S=0时,表示这个浮点数为正值;S=1表示这个浮点数为负值。M表示有效数字,大于等于1,小于2,上例中有效数字M就是1.01101。2^E表示指数位,上例中E=2。如图所示
以5.625举例子,5.625的二进制位形式是101.101
这是浮点数在内存中的存储形式
E+127/255存入,M去掉1存入
说了这么多,但是浮点数在内存中到底是如何计算的呢?
其实浮点数计算和存储的时候还是略有差别
浮点数计算规则
1.指数向高位对齐
什么意思呢?
如果两个浮点数进行相加,一个的E=3,一个的E=2,那么就要将E=2的浮点数转化为E=3的浮点数
转化方法就是改变这个浮点数的有效数字,将有效数字再次前移
例如5.625要与9.125相加
5,625的E=2,有效数字为1.01101
9.125的E=3,有效数字为1.001001
5.625的E小于9.125的E,所以将5.625的E改为3,同时将它的有效数字前移1位
从1.01101变成0.101101
所以在计算的时候,5.625的V就变了,如图
将改变之后的M部分按二进制位运算方法运算,这个结果就是最终结果的有效数字
再将这个数字乘指数部分即可以得到最终结果
2.运算过程中的进位问题
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
s.csdn.net/topics/618668825)**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!