JavaScript浮点运算
我试着做了一些浮点比较,结果如下:JavaScript浮点运算,javascript,floating-point,comparison,Javascript,Floating Point,Comparison,我试着做了一些浮点比较,结果如下: 130 === 130.000000000000014210854715 // true 130 === 130.000000000000014210854716 // false 9 === 9.0000000000000008881784197001 // true 9 === 9.0000000000000008881784197002 // false 0.1 === 0.100000000000000012490009027033 // true 0
130 === 130.000000000000014210854715 // true
130 === 130.000000000000014210854716 // false
9 === 9.0000000000000008881784197001 // true
9 === 9.0000000000000008881784197002 // false
0.1 === 0.100000000000000012490009027033 // true
0.1 === 0.100000000000000012490009027034 // false
我试着在Firefox和Chrome上运行它们,结果是一样的。好的,我知道浮点比较是一种不好的做法,并且有意外的行为。但我只是好奇这些数字,为什么或者如何计算这些小数位数序列
如果您希望进一步扩展这些序列(类似于二进制搜索下一个序列) 分数部分超过了JavaScript的
数字
类型的精度
JavaScript只能处理数字的130.0000000000000
部分,因此它变成130
(那些0
s没有意义)
JavaScript中的每个数字实际上都是64位浮点,因此数字130.0000000000000 14210854715
看起来像二进制
0,10000000110,10000010000000000000000000000000000000000000000000000
其中组为符号(+
或-
)、指数和有效位/尾数
您可以看到编号130
是相同的
0,10000000110,10000010000000000000000000000000000000000000000000000
你需要一个128位的数字
让JavaScript能够区分这两个数字,而不是用a来表示JavaScript或。那么130.000000000000014210854716二进制怎么样?@CaptainkurO它打开了尾数的最后一位:00000100000000000000000000000000000001