探索 JavaScript 的现代原语:BigInt 和 Symbol

探索 javascript 的现代原语:bigint 和 symbol

在不断发展的 javascript 世界中,引入了新功能来解决该语言的局限性,并为开发人员提供更强大的工具来构建应用程序。 bigint 和 symbol 原语就是两个这样的功能,它们都是在 ecmascript 2015 (es6) 及更高版本中引入的。这些类型为 javascript 带来了新功能,使开发人员能够处理大整数并轻松创建唯一标识符。

了解 bigint

javascript 中的 bigint 类型旨在表示大于 number 类型的安全整数限制(2^{53} - 1)的整数。 bigint 类型允许您处理超出此限制的数字而不损失精度,使其成为密码学、科学计算和金融应用程序用例的理想选择。

创建 bigint 值

创建 bigint 非常简单。您可以使用 n 后缀表示文字,或使用 bigint 构造函数表示字符串或数字:

// using the 'n' suffix
const bigint1 = 1234567890123456789012345678901234567890n;

// using the bigint constructor
const bigint2 = bigint("1234567890123456789012345678901234567890");

bigint 操作

您可以使用 bigint 执行算术运算,就像使用常规数字一样,但有一些注意事项。 bigint 和 number 之间的运算需要显式转换:

const bigint = 100000000000000000000n;
const num = 2;

// addition
const sum = bigint + bigint(num); // 100000000000000000002n

// multiplication
const product = bigint * 3n; // 300000000000000000000n

// division
const quotient = bigint / 2n; // 50000000000000000000n

bigint 的注意事项

  • 禁止混合类型:您必须在 bigint 和 number 之间显式转换。
  • 没有小数:bigint 严格适用于整数。
  • 性能:由于开销,操作可能比使用 number 的操作慢。
  • json 兼容性:bigint 无法直接序列化为 json

理解符号

javascript 中的 symbol 类型表示一个唯一且不可变的值,可以用作对象属性的标识符。 符号在属性键需要唯一的情况下或者当您想要向对象添加元数据而不冒属性名称冲突的风险时特别有用。

创建符号

符号是使用 symbol() 函数创建的。每次调用都会返回一个唯一的符号:

const sym1 = symbol();
const sym2 = symbol('description');

console.log(sym1 === sym2); // false

在对象中使用符号

符号通常用作对象属性的键,提供一种私有属性的形式:

const sym = symbol('mysymbol');

const myobject = {
  [sym]: 'value'
};

console.log(myobject[sym]); // 'value'

符号不会出现在标准属性枚举中:

console.log(object.keys(myobject)); // []
console.log(object.getownpropertysymbols(myobject)); // [ symbol(mysymbol) ]

众所周知的符号

javascript 包含众所周知的符号,允许您修改内置操作的行为:

  • symbol.iterator:为对象定义自定义迭代。
  • symbol.toprimitive:自定义类型转换。
  • symbol.tostringtag:更改默认字符串描述。

自定义迭代示例:

const myiterable = {
  *[symbol.iterator]() {
    yield 1;
    yield 2;
    yield 3;
  }
};

for (const value of myiterable) {
  console.log(value); // 1, 2, 3
}

全球符号注册表

可以使用全局符号注册表通过 symbol.for() 和 symbol.keyfor() 共享符号:

const globalSym1 = Symbol.for('globalSymbol');
const globalSym2 = Symbol.for('globalSymbol');

console.log(globalSym1 === globalSym2); // true
console.log(Symbol.keyFor(globalSym1)); // 'globalSymbol'

结论

bigint 和 symbol 原语显着增强了 javascript 的功能,提供了处理大整数和创建唯一属性键的解决方案。通过理解和利用这些现代原语,开发人员可以编写更强大、更灵活的代码,避免与传统数据类型相关的潜在陷阱。无论您是处理大数值还是需要唯一标识符,这些功能都是 javascript 工具包中不可或缺的工具。

以上就是探索 JavaScript 的现代原语:BigInt 和 Symbol的详细内容,更多请关注其它相关文章!