前端JavaScript基础训练系列九十三:32 位有符号整数

虽然整数最大能够达到 53 位,但是有些数字操作(如数位操作)只适用于 32 位数字, 所以这些操作中数字的安全范围就要小很多,变成从 Math.pow(-2,31)(-2147483648, 约-21 亿)到 Math.pow(2,31) - 1(2147483647,约 21 亿)。
a | 0可以将变量a中的数值转换为32位有符号整数,因为数位运算符|只适用于32位 整数(它只关心 32 位以内的值,其他的数位将被忽略)。因此与 0 进行 OR 操作本质上没 有意义。

某些特殊的值并不是 32 位安全范围的,如 NaN 和 Infinity(下节将作相关 介绍),此时会对它们执行虚拟操作(abstract operation)ToInt32,以便转换为符合数位运算符要求的 +0 值。

特殊数值

JavaScript 数据类型中有几个特殊的值需要开发人员特别注意和小心使用。

不是值的值

undefined 类型只有一个值,即 undefined。null 类型也只有一个值,即 null。它们的名
称既是类型也是值。
undefined 和 null 常被用来表示“空的”值或“不是值”的值。二者之间有一些细微的差 别。例如:
• null 指空值(empty value)
• undefined 指没有值(missing value)
或者:
• undefined 指从未赋值
• null 指曾赋过值,但是目前没有值
null 是一个特殊关键字,不是标识符,我们不能将其当作变量来使用和赋值。然而
undefined 却是一个标识符,可以被当作变量来使用和赋值。 2.4.2 undefined
在非严格模式下,我们可以为全局标识符 undefined 赋值(这样的设计实在是欠考虑!):

function foo() {
undefined = 2; // 非常糟糕的做法!
}
foo();
     function foo() {
         "use strict";
         undefined = 2; // TypeError!
     }
foo();

在非严格和严格两种模式下,我们可以声明一个名为 undefined 的局部变量。再次强调最 好不要这样做!

    function foo() {
         "use strict";
         var undefined = 2;
         console.log( undefined ); // 2
     }
foo();

永远不要重新定义 undefined。

void 运算符

undefined 是一个内置标识符(除非被重新定义,见前面的介绍),它的值为 undefined, 通过 void 运算符即可得到该值。
表达式void ___没有返回值,因此返回结果是undefined。void并不改变表达式的结果, 只是让表达式不返回值:

    var a = 42;
     console.log( void a, a ); // undefined 42

按惯例我们用void 0来获得undefined(这主要源自C语言,当然使用void true或其他 void 表达式也是可以的)。void 0、void 1 和 undefined 之间并没有实质上的区别。
void 运算符在其他地方也能派上用场,比如不让表达式返回任何结果(即使其有副作用)。 例如:

function doSomething() {
// 注:APP.ready 由程序自己定义 if (!APP.ready) {
// 稍后再试
             return void setTimeout( doSomething,100 );
         }
var result;
// 其他
         return result;
     }
// 现在可以了吗?
if (doSomething()) {
// 立即执行下一个任务 }

这里 setTimeout(…) 函数返回一个数值(计时器间隔的唯一标识符,用来取消计时),但是为了确保 if 语句不产生误报(false positive),我们要 void 掉它。 很多开发人员喜欢分开操作,效果都一样,只是没有使用 void 运算符:

if (!APP.ready) { // 稍后再试
         setTimeout( doSomething,100 );
return; }

总之,如果要将代码中的值(如表达式的返回值)设为 undefined,就可以使用 void。这 种做法并不多见,但在某些情况下却很有用。

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值