2020-04-14
描述
检查给定的数字是否等于负零(-0
)。
提示
- 传入的值是否等于
0
- 并且用
1
除以该值是否等于-Infinity
代码
const isNegativeZero = val => val === 0 && 1 / val === -Infinity;
示例
是否为负零:
isNegativeZero(-0); // true
isNegativeZero(0); // false
2020-04-14
检查给定的数字是否等于负零(-0
)。
0
1
除以该值是否等于 -Infinity
const isNegativeZero = val => val === 0 && 1 / val === -Infinity;
是否为负零:
isNegativeZero(-0); // true
isNegativeZero(0); // false
JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。
还有一种常见的写法(更直观些):
const isNegativeZero = val => Object.is(val, -0.);
最初发现 0. === -0.
的时候感觉很惊讶,以为 V8 引擎有 bug。然后读了下 ECMA-262:
If Type(x) is Number, then
- If x is NaN, return false.
- If y is NaN, return false.
- If x is the same Number value as y, return true.
- If x is +0 and y is −0, return true.
- If x is −0 and y is +0, return true.
- Return false.
好吧,基础不牢地动山摇
为了应对这种尴尬,有一个提案:Math.signbit()
,获取浮点数中标明正负的一位,也就是 IEEE 754 中的规定的最高位,这样就可以优雅地(并不)判断正负 0 了:
const isNegativeZero = val => val === 0 && Math.signbit(val);
当然,用位运算是获取不到符号位的,因为在位运算之前会被转换为 32 位无符号整型。 当然,我们还可以自己动手用位运算获取最高位(实操的话可以直接先判断是否 === 0
,然后再判断有没有非 0 的位就可以了,避免了区分大小端的必要),如下所示:
const isNegativeZero = val => {
if (val !== 0) {
return false;
}
let arr = new Float64Array(1);
arr.set([val], 0);
let dw = new DataView(arr.buffer);
return !!(dw.getUint32(0) || dw.getUint32(4));
}
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于