0

0

Javascript中的Map和Set数据结构是什么?

紅蓮之龍

紅蓮之龍

发布时间:2025-12-13 12:06:07

|

568人浏览过

|

来源于php中文网

原创

Map 和 Set 是 JavaScript 中高效管理键值对和唯一值的内置集合类型:Map 键可为任意类型且保持插入顺序,Set 自动去重并支持快速成员判断。

javascript中的map和set数据结构是什么?

MapSet 是 JavaScript 中两种内置的集合类型,用于更高效、更语义化地管理键值对和唯一值。

Map:带顺序的键值对集合

Map 类似于对象(Object),但更灵活:它的键可以是任意类型(字符串、数字、对象、函数、Symbol 等),且会按插入顺序遍历。对象的键只能是字符串或 Symbol,且不保证遍历顺序(尤其在涉及数字键时)。

常用操作:

用Apache Spark进行大数据处理
用Apache Spark进行大数据处理

本文档主要讲述的是用Apache Spark进行大数据处理——第一部分:入门介绍;Apache Spark是一个围绕速度、易用性和复杂分析构建的大数据处理框架。最初在2009年由加州大学伯克利分校的AMPLab开发,并于2010年成为Apache的开源项目之一。 在这个Apache Spark文章系列的第一部分中,我们将了解到什么是Spark,它与典型的MapReduce解决方案的比较以及它如何为大数据处理提供了一套完整的工具。希望本文档会给有需要的朋友带来帮助;感

下载
  • 创建:const map = new Map()new Map([[key1, val1], [key2, val2]])
  • 增/改:map.set(key, value)
  • 查:map.get(key),不存在返回 undefined
  • 删:map.delete(key),返回布尔值表示是否删除成功
  • 判断存在:map.has(key)
  • 清空:map.clear()
  • 获取大小:map.size(是属性,不是方法)

Set:只存唯一值的集合

Set 存储一组互不重复的值,不限类型。它不关心“键”和“值”的对应关系,只关注“这个值是否已存在”。常用来去重或做成员判断。

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

常用操作:

  • 创建:const set = new Set()new Set([1, 2, 2, 3]) → 自动去重为 {1, 2, 3}
  • 添加:set.add(value)(重复添加无效)
  • 判断存在:set.has(value)
  • 删除:set.delete(value)
  • 清空:set.clear()
  • 获取大小:set.size

和 Object / Array 的主要区别

Object 的键会被强制转为字符串,导致 {[1]: 'a', [true]: 'b'} 实际变成 {'1': 'a', 'true': 'b'};Map 则保留原始键类型。
Array 虽可模拟集合,但查找、去重、判断存在都要遍历,时间复杂度 O(n);Map 和 Set 的 gethasadd 均为平均 O(1)。

另外,Map 和 Set 都是可迭代对象,支持 for...of、扩展运算符([...map])、解构等。

什么时候该用 Map 或 Set?

Map 当你需要:键不是字符串/Symbol、需要保持插入顺序、频繁增删查键值对、以对象为键(比如缓存 DOM 元素对应的数据)。

Set 当你需要:快速去重(如 [...new Set(arr)])、高效判断某值是否存在(比 arr.includes() 快得多)、统计唯一项数量。

基本上就这些。它们不是替代 Object 或 Array 的工具,而是补足了 JS 在数据组织上的关键缺口。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1503

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

87

2025.10.17

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

531

2023.09.20

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1503

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

625

2023.11.24

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

54

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.4万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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