我们在控制台中输入0.1+0.2,显然结果不是0.3,那么问什么会这样呢?
要了解这个问题,首先得明白浮点型在计算机中的存储方式
js中,浮点型总共64位,最高位为符号位,接下来11为指数位,那么剩下的52位就是小数位,我们可以推断,如果小数是无限循环小数,那么是不是只能保存其52位,剩余的肯定要舍去。
而我们的问题的答案就是这个原因 ,以0.1+0.2为例,首先这两个浮点数计算是先转化为二进制的,
- 0.1转化为2进制为:0.00001100110011001100110011…无限循环
- 0.2转化为2进制为:0.0011001100110011001100110011…无限循环
- 那么0.1+0.2相加保留其小数点后52位为:0.01001100110011001100 … 1100,
- 那么将转化为10进制:0.30000…004