1.在计算机中 存储都是2进制的, 数字计算时也会先转换成2进制再进行计算
2.十进制 => 二进制
如何转化的?
0.1 可以把 0看做整数位 1看做是小数位
规则:
* 整数位 当前位的值*2^(n-1) 当前位的值乘以2的n-1次密
* 小数位 把当前位的值不停的*2取整
1.举个整数的例子:
二进制数1010 => 0*2^0 + 1*2^1 + 0*2^2 + 1*2^3 = 0 + 2 + 0 + 8 = 10
不信你用 parseInt('1010', 2) 验证一下
2.再举个小数的例子:
0.1 转换成2进制
0.1 * 2 = 0.2 无整数 0.0
0.2 * 2 = 0.4 无整数 0.00
0.4 * 2 = 0.8 无整数 0.000
0.8 * 2 = 1.6 有整数 0.0001 余0.6
0.6 * 2 = 1.2 有整数 0.00011 余 0.2
0.2 * 2 = 0.4 无限循环了
不信的话 用0.1.toString(2) 验证一下
console.log(parseInt('1010', 2)); // 10
console.log((0.1).toString(2)); // 0.0001100110011001100110011001100110011001100110011001101 (有限位是由于js是双精度浮点数)
console.log((0.2).toString(2)); // 0.001100110011001100110011001100110011001100110011001101
所以两个无限循环小数 相加 在转化成2进制的时候,就已经出现了偏差,所以相加的结果不等于0.3