news 2026/4/16 9:18:02

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/4/14 5:46:03

学习Java的技巧

吃透Java的实用技巧&#xff0c;从入门到进阶不走弯路作为一门经典的面向对象编程语言&#xff0c;Java不仅是计算机专业学子的必修课&#xff0c;也是很多后端开发者的入门首选。想要学好Java&#xff0c;靠死记硬背远远不够&#xff0c;找对方法才能事半功倍。分享几个亲测有…

作者头像 李华
网站建设 2026/4/10 11:23:27

实时协作文档编辑:用Tiptap打造团队写作新体验

实时协作文档编辑&#xff1a;用Tiptap打造团队写作新体验 【免费下载链接】tiptap The headless editor framework for web artisans. 项目地址: https://gitcode.com/GitHub_Trending/ti/tiptap 在远程办公成为常态的今天&#xff0c;团队协作文档编辑不再是可有可无的…

作者头像 李华
网站建设 2026/4/14 9:35:28

31、Linux系统管理与编程基础全解析

Linux系统管理与编程基础全解析 1. 编程基础 1.1 课程目标 编程部分涵盖了几个重要的目标: - 理解C编程基础 - 掌握GNU构建工具链 - 了解共享库的概念 - 执行标准构建流程 需要明确的是,相关考试面向系统管理员,而非开发者或程序员。不过,了解开发过程有助于有效沟…

作者头像 李华
网站建设 2026/4/1 23:39:32

svg2gcode:免费快速实现矢量图形到G代码的终极转换工具

svg2gcode&#xff1a;免费快速实现矢量图形到G代码的终极转换工具 【免费下载链接】svg2gcode Convert vector graphics to g-code for pen plotters, laser engravers, and other CNC machines 项目地址: https://gitcode.com/gh_mirrors/sv/svg2gcode 想要将精美的SV…

作者头像 李华
网站建设 2026/4/12 17:41:27

终极Node.js打印机控制实战:5步搞定ESC/POS设备集成

终极Node.js打印机控制实战&#xff1a;5步搞定ESC/POS设备集成 【免费下载链接】node-escpos &#x1f5a8;️ ESC/POS Printer driver for Node.js 项目地址: https://gitcode.com/gh_mirrors/no/node-escpos 在现代商业应用开发中&#xff0c;ESC/POS打印技术已经成为…

作者头像 李华