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 就比数组更直接、更省资源:
标签: javascript java 工具 区别 red
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~