Set是JavaScript中用于存储唯一值的内置集合,专为去重和存在性判断优化,具有O(1)查找、自动去重及add/delete/has等语义清晰的操作接口。

JavaScript 中的 Set 是一种内置集合数据结构,它只存储唯一值——重复添加的值会被自动忽略。它不是数组的替代品,而是为“去重”和“存在性判断”这类场景专门优化的工具。
核心区别:设计目标与行为逻辑不同
数组(Array)是有序、可索引、允许重复的数据容器,适合按位置存取、遍历、映射等操作;而 Set 是无序、无索引、强制唯一的集合,不关心顺序,也不提供下标访问(如 set[0] 无效),只关注“某个值是否存在”或“所有值有哪些”。
- 数组用
indexOf()或includes()查元素,时间复杂度是 O(n);Set 的has()方法接近 O(1),查得快得多。 - 数组需要手动过滤才能去重(比如
[...new Set(arr)]或filter((v, i) => arr.indexOf(v) === i));Set 在初始化或add()时就自动去重,一步到位。 - 数组有
length、支持map/reduce/sort等丰富方法;Set 没有这些,但提供语义清晰的集合操作接口:add、delete、has、size、clear。
典型优势场景:去重和成员检测更自然高效
当你只需要确认某值是否已存在,或确保一批数据没有重复,Set 就比数组更直接、更省资源:
-
一行去重:
[...new Set([1,2,2,3])] → [1,2,3],比手写循环或 filter 简洁可靠。 -
高频查找:比如在表单校验中维护已提交的用户 ID 列表,用
idSet.has(id)判断是否重复,性能远优于在长数组里反复includes。 -
集合运算友好:配合展开运算符和数组方法,轻松实现交集、差集等,例如:
const intersection = new Set([...setA].filter(x => setB.has(x))));
注意边界:Set 不是万能的“高级数组”
它不支持索引访问、不能直接排序、不保留插入顺序以外的“逻辑顺序”(虽然实际迭代按插入顺序,但这是实现细节,非规范保证)。如果业务依赖下标、需要频繁按位置修改、或必须保持严格排序,数组仍是首选。Set 的价值不在“功能多”,而在“做对的事更轻更快”。
立即学习“Java免费学习笔记(深入)”;











