我只是好奇,为什么在IEEE-754任何非零浮点数除以零时会产生无穷大的值?从数学角度来看,这是无稽之谈.所以我认为这个操作的正确结果是NaN.
如果x是实数,则当x = 0时,不定义函数f(x)= 1/x.例如,如果IEEE-754生成NaN值,则不为任何负数定义函数sqrt,并为sqrt(-1.0f)定义函数sqrt .但1.0f/0是Inf.
但由于某些原因,事实并非如此IEEE-754.必须有一个原因,可能是一些优化或兼容性原因.
那有什么意义呢?
事实证明,+0 === -0计算结果为true,尽管+0和-0是不同的实体.那么,你如何区分+0从-0?
有一个黑客:
if (1 / myZero > 0) {
// myZero is +0
} else {
// myZero is -0
}
Run Code Online (Sandbox Code Playgroud)
我可以做得更好吗?
我坚持下面提到的这种特殊情况.有人可以向我解释下列行为的原因是什么.
Infinity - Infinity结果为何NaN, but NaN === (Infinity-Infinity)结果false如何?