news 2026/1/16 14:04:30

Java中Set集合的概念

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java中Set集合的概念

java.util.Set 是 Java 集合框架的子接口,继承自 Collection 接口,核心特征是存储的元素无序且不可重复,不支持通过索引访问元素。

一、核心特性

1. 元素唯一性

Set 集合不允许存储重复元素,判断元素是否重复的依据是 equals() 方法和 hashCode() 方法——两个元素若 equals() 返回 true ,则 hashCode() 必须相等,反之不一定。当向 Set 中添加重复元素时, add() 方法会返回 false ,且集合不会发生变化。

2. 无序性

这里的无序指元素不会按插入顺序保存,也没有索引下标。遍历 Set 集合时,元素的输出顺序可能与插入顺序不同,具体表现由不同实现类决定。

3. 允许存储 null 元素

大部分 Set 实现类(如 HashSet )支持存储一个 null 元素, TreeSet 则不支持,向其存入 null 会抛出 NullPointerException 。

4. 线程不安全

常用的 HashSet 、 TreeSet 等实现类默认线程不安全,若多线程并发修改,需手动通过 Collections.synchronizedSet() 方法包装成线程安全的集合。

二、常用实现类

1. HashSet

基于 HashMap 实现,元素会作为 HashMap 的 key 存储。它的存取效率高,时间复杂度接近 O(1);元素无序;允许存储一个 null 元素;依赖 hashCode() 和 equals() 保证元素唯一性。

2. LinkedHashSet

基于 LinkedHashMap 实现,继承自 HashSet 。它兼具 HashSet 的元素唯一性,同时会维护元素的插入顺序,遍历顺序与插入顺序一致;存取效率略低于 HashSet。

3. TreeSet

基于红黑树实现。元素会自动按自然顺序(需实现 Comparable 接口)或指定比较器( Comparator )排序;不允许存储 null 元素;存取、查找的时间复杂度为 O(log n);元素唯一性通过比较器或 compareTo() 方法判断。

三、常用方法

Set 接口继承自 Collection 接口,常用方法如下:

1. 添加元素: boolean add(E e) —— 添加成功返回 true ,元素重复返回 false ; boolean addAll(Collection<? extends E> c) —— 添加另一个集合的所有元素。

2. 删除元素: boolean remove(Object o) —— 删除指定元素,成功返回 true ; void clear() —— 清空集合。

3. 判断元素: boolean contains(Object o) —— 判断集合是否包含指定元素; boolean isEmpty() —— 判断集合是否为空。

4. 获取长度: int size() —— 返回集合中元素的个数。

5. 遍历方式:支持增强 for 循环、迭代器(Iterator)遍历,不支持普通 for 循环(无索引)。

四、使用注意事项

1. 向 Set 中存储自定义对象时,必须重写 equals() 和 hashCode() 方法,否则无法保证元素唯一性,因为默认会使用 Object 类的方法,比较的是对象地址。

2. TreeSet 存储的元素要么实现 Comparable 接口,要么在创建 TreeSet 时传入 Comparator 比较器,否则会抛出 ClassCastException 。

3. HashSet 的元素顺序可能受元素 hashCode 影响,不要依赖其遍历顺序;若需有序,优先使用 LinkedHashSet 。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/2 13:27:49

科技发展的ai

科技发展的双重赋能与治理困境&#xff1a;在创新与平衡中探寻可持续路径摘要科技发展作为人类文明进步的核心驱动力&#xff0c;在重塑经济结构、优化生活方式、破解全球难题等方面展现出颠覆性力量。从智能手机普及到人工智能赋能产业升级&#xff0c;从绿色技术革新到跨领域…

作者头像 李华
网站建设 2026/1/2 1:23:30

Java基础阶段练手项目清单

Java基础阶段练手项目清单这份清单覆盖语法应用、逻辑训练、简单数据处理等核心能力&#xff0c;适合刚学完基础语法的新手&#xff0c;无需框架&#xff0c;只用JDK即可完成。1. 控制台计算器- 核心需求&#xff1a;实现加、减、乘、除、取余运算&#xff0c;支持输入两个数字…

作者头像 李华
网站建设 2026/1/9 18:08:09

30、Linux系统操作与资源指南

Linux系统操作与资源指南 1. info工具的操作 info工具是Linux系统中常用的帮助工具,其相关文件存放在 /usr/share/info 目录下。在info工具中,有一些常用的组合键操作,如下表所示: | 组合键 | 操作 | | — | — | | 空格键、PageDown | 向下滚动到下一页 | | 退格键…

作者头像 李华
网站建设 2026/1/3 23:19:19

9.有人网络转RS485模块的使用

可能是水平问题&#xff0c;个人不太喜欢用QT的串口类&#xff0c;进行开发&#xff0c;宁可转一下。有人的网络转RS485&#xff0c;比较喜欢用。这里记录一下&#xff0c;使用方法&#xff1a;设置成服务端&#xff1a;然后&#xff0c;保存重启即可。此时模块就变成一个网络转…

作者头像 李华
网站建设 2026/1/2 17:06:39

HSWeb框架企业级权限管理系统终极指南:从入门到精通

HSWeb框架企业级权限管理系统终极指南&#xff1a;从入门到精通 【免费下载链接】hsweb-framework hsweb (haʊs wɛb) 是一个基于spring-boot 2.x开发 ,首个使用全响应式编程的企业级后台管理系统基础项目。 项目地址: https://gitcode.com/gh_mirrors/hs/hsweb-framework …

作者头像 李华
网站建设 2026/1/6 15:54:00

ThinkPad T480终极改造:用OpenCore实现完美macOS体验的完整指南

ThinkPad T480终极改造&#xff1a;用OpenCore实现完美macOS体验的完整指南 【免费下载链接】t480-oc &#x1f4bb; Lenovo ThinkPad T480 / T580 / X280 Hackintosh (macOS Monterey 12.x & Ventura 13.x) - OpenCore 项目地址: https://gitcode.com/gh_mirrors/t4/t48…

作者头像 李华