网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
今天分享的文章来一个灵魂拷问,你知道在Python中,0.1 + 0.2 等于几吗?
为啥会有上述图片的现象呢?其实是由于float底层存储原理导致,下面听我娓娓道来。
第一步:浮点数转换为二进制表示
-
整数部分,直接转换为二进制,即:`100111`
-
小数部分,让小数一直乘2,小于1则用结果继续乘,大于1则结果减1继续乘,等于1则结束。
如果小数位是0.25就会比较简单,例如:
0.25 * 2 = 0.5 // 小于1,则继续乘
0.5 * 2 = 1 // 等于1,则结束
结束时,将相乘之后等结果的整数部分拼接起来,所以 0.25 的二进制表示:01
第二步:科学计数法表示二进制小数
注意:因为是二进制小数,所以底数是2。
第三步:存储
-
Float32,用32位的二进制来存储一个浮点数。
-
Float64,用64位的二进制来存储一个浮点数。
接下来,我们以float32为例:
感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:
① 2000多本Python电子书(主流和经典的书籍应该都有了)
② Python标准库资料(最全中文版)
③ 项目源码(四五十个有趣且经典的练手项目及源码)
④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)
⑤ Python学习路线图(告别不入流的学习)
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!