(1) 为什么“0.1+0.2=0.30000000000000004”?
首先声明这不是bug,原因在与十进制到二进制的转换导致的精度问题!
其实这是很多编程语言都有的问题:是因为使用了IEEE 754浮点数格式来存储浮点类型的编程语言都具有这个问题。
IEEE754-2008中的64位浮点数规则定义的小数后的有效位数至多为52位导致计算出现精度丢失问题!
0.1十进制转二进制:0.000110011001100110011(0011)无限循环。
0.2十进制转二进制0.0011001100110011…(循环0011)
最后:
0.00011001100110011001100110011001100110011001100110011001
+0.00110011001100110011001100110011001100110011001100110011
= 0.01001100110011001100110011001100110011001100110011001100
转换成10进制之后得到:0.30000000000000004!
总结:
Math.round(-5.5)等于多少?
Math.round(-5.5)的返回值是-5,Math.round(5.5)的返回值是6。四舍五入的原理是在参数上加0.5然后做向下取整。