首页 > web前端 > js教程 > 正文

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

花韻仙語
发布: 2024-10-15 08:00:02
转载
785人浏览过

探索 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
登录后复制

在对象中使用符号

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

讯飞智作-讯飞配音
讯飞智作-讯飞配音

讯飞智作是一款集AI配音、虚拟人视频生成、PPT生成视频、虚拟人定制等多功能的AI音视频生产平台。已广泛应用于媒体、教育、短视频等领域。

讯飞智作-讯飞配音 67
查看详情 讯飞智作-讯飞配音
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); // true
console.log(Symbol.keyFor(globalSym1)); // 'globalSymbol'
登录后复制

结论

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

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

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号