Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/439.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
JavaScript浮点运算_Javascript_Floating Point_Comparison - Fatal编程技术网

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