探索 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' suffixconst bigint1 = 1234567890123456789012345678901234567890n;// using the bigint constructorconst bigint2 = bigint("1234567890123456789012345678901234567890");

登录后复制

bigint 操作

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

const bigint = 100000000000000000000n;const num = 2;// additionconst sum = bigint + bigint(num); // 100000000000000000002n// multiplicationconst product = bigint * 3n; // 300000000000000000000n// divisionconst 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 包含众所周知的符号,允许您修改内置操作的行为:

立即学习“Java免费学习笔记(深入)”;

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); // trueconsole.log(Symbol.keyFor(globalSym1)); // 'globalSymbol'

登录后复制

结论

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2664492.html

(0)
上一篇 2025年3月7日 11:39:20
下一篇 2025年3月3日 08:54:10

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论