Java 23 集合框架详解:Set 接口及实现类(HashSet、TreeSet、LinkedHashSet)
📚 Java 23 集合框架详解:Set 接口及实现类(HashSet、TreeSet、LinkedHashSet)
📖 概述
Set 是 Java 集合框架中用于存储 无序、不重复元素 的接口。它的实现类包括 HashSet、TreeSet 和 LinkedHashSet,它们在底层数据结构、排序规则和性能特性上存在显著差异。
本文将详细介绍 Set 接口及其实现类 的使用案例、底层实现、性能优化方案、多线程优化及注意事项。
🏗️ 1. Set 接口的常用实现类
| 实现类 | 底层数据结构 | 排序方式 | 是否允许 null | 线程安全性 |
|---|---|---|---|---|
HashSet | 哈希表 | 无序 | 允许 | 否 |
TreeSet | 红黑树 | 自然顺序/自定义排序 | 不允许 | 否 |
LinkedHashSet | 哈希表 + 双向链表 | 按插入顺序 | 允许 | 否 |
📋 2. HashSet 详解
✅ 2.1 特点
- 基于哈希表实现,元素按 哈希值 存储,存取效率高。
- 不保证元素顺序。
- 允许存储一个
null值。 - 插入、删除、查找操作的平均时间复杂度为 O(1)。
🔧 2.2 使用案例
import java.util.HashSet;public class HashSetExample {public static void main(String[] args) {HashSet<String> set = new HashSet<>();set.add("Alice");set.add("Bob");set.add("Charlie");// 尝试添加重复元素set.add("Alice");// 遍历set.forEach(System.out::println);}
}
输出:
Alice
Bob
Charlie
🛠 2.3 优化方案
- 指定初始容量和负载因子:
HashSet<String> set = new HashSet<>(16, 0.75f); - 避免频繁扩容,设置合适的初始容量,减少性能开销。
⚠️ 2.4 多线程优化
HashSet 是 线程不安全的,可以使用 Collections.synchronizedSet() 方法或 ConcurrentHashMap 来实现线程安全。
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;public class SynchronizedHashSetExample {public static void main(String[] args) {Set<String> synchronizedSet = Collections.synchronizedSet(new HashSet<>());synchronizedSet.add("Alice");synchronizedSet.add("Bob");synchronized (synchronizedSet) {synchronizedSet.forEach(System.out::println);}}
}
📋 3. TreeSet 详解
✅ 3.1 特点
- 基于红黑树实现,元素按 自然顺序 或 自定义顺序 排序。
- 不允许存储
null值。 - 插入、删除、查找操作的时间复杂度为 O(log n)。
🔧 3.2 使用案例
import java.util.TreeSet;public class TreeSetExample {public static void main(String[] args) {TreeSet<Integer> set = new TreeSet<>();set.add(20);set.add(10);set.add(30);// 遍历set.forEach(System.out::println);}
}
输出:
10
20
30
🔧 使用自定义排序
import java.util.TreeSet;
import java.util.Comparator;public class CustomTreeSetExample {public static void main(String[] args) {TreeSet<String> set = new TreeSet<>(Comparator.reverseOrder());set.add("Alice");set.add("Bob");set.add("Charlie");set.forEach(System.out::println);}
}
输出:
Charlie
Bob
Alice
🛠 3.3 优化方案
- 避免使用
null值,因为TreeSet不允许存储null。 - 选择合适的排序规则,根据业务需求使用 自然顺序 或 自定义排序。
⚠️ 3.4 多线程优化
TreeSet 是 线程不安全的,可以使用 Collections.synchronizedSet() 来实现线程安全。
import java.util.Collections;
import java.util.TreeSet;
import java.util.Set;public class SynchronizedTreeSetExample {public static void main(String[] args) {Set<Integer> synchronizedSet = Collections.synchronizedSet(new TreeSet<>());synchronizedSet.add(10);synchronizedSet.add(20);synchronized (synchronizedSet) {synchronizedSet.forEach(System.out::println);}}
}
📋 4. LinkedHashSet 详解
✅ 4.1 特点
- 基于哈希表和双向链表实现。
- 保留元素的插入顺序。
- 允许存储一个
null值。
🔧 4.2 使用案例
import java.util.LinkedHashSet;public class LinkedHashSetExample {public static void main(String[] args) {LinkedHashSet<String> set = new LinkedHashSet<>();set.add("Alice");set.add("Bob");set.add("Charlie");// 遍历set.forEach(System.out::println);}
}
输出:
Alice
Bob
Charlie
🛠 4.3 优化方案
- 使用
LinkedHashSet时,考虑内存占用问题,因为双向链表会占用更多内存。 - 适用于需要按插入顺序遍历的场景。
⚠️ 4.4 多线程优化
LinkedHashSet 是 线程不安全的,可以使用 Collections.synchronizedSet() 来实现线程安全。
import java.util.Collections;
import java.util.LinkedHashSet;
import java.util.Set;public class SynchronizedLinkedHashSetExample {public static void main(String[] args) {Set<String> synchronizedSet = Collections.synchronizedSet(new LinkedHashSet<>());synchronizedSet.add("Alice");synchronizedSet.add("Bob");synchronized (synchronizedSet) {synchronizedSet.forEach(System.out::println);}}
}
🔄 5. 三者对比总结
| 特性 | HashSet | TreeSet | LinkedHashSet |
|---|---|---|---|
| 底层数据结构 | 哈希表 | 红黑树 | 哈希表 + 双向链表 |
是否允许 null | 是 | 否 | 是 |
| 排序方式 | 无序 | 自然顺序/自定义排序 | 插入顺序 |
| 插入/删除性能 | O(1) | O(log n) | O(1) |
| 适用场景 | 快速查找和去重 | 排序数据集 | 保留插入顺序 |
🎯 6. 选择指南
| 场景 | 推荐实现类 |
|---|---|
| 快速查找和去重 | HashSet |
| 需要排序的集合 | TreeSet |
| 需要保留插入顺序的集合 | LinkedHashSet |
⚙️ 7. 总结
HashSet适用于 快速查找和去重 的场景。TreeSet适用于 需要排序的集合。LinkedHashSet适用于 需要保留插入顺序的集合。
相关文章:
Java 23 集合框架详解:Set 接口及实现类(HashSet、TreeSet、LinkedHashSet)
📚 Java 23 集合框架详解:Set 接口及实现类(HashSet、TreeSet、LinkedHashSet) 📖 概述 Set 是 Java 集合框架中用于存储 无序、不重复元素 的接口。它的实现类包括 HashSet、TreeSet 和 LinkedHashSet,它…...
ARMv8架构 CortexR52+ 内核 coresight_soc400介绍
前言:笔者在工作中接触到了一款多核芯片,其采用的处理器为CortexR52,使用的架构为ARMv8,我通过CoreSight SOC-400组件完成了对该芯片烧录代码的开发。这里芯片型号就不透露了,本文仅介绍我自己从ARM官网上提供的R52核等…...
1.Python浅过(语法基础)
1.简介 Python是一种面向对象的解释型高级编程语言,是强类型的动态脚本语言。 解释型语言跨平台性比编译型语言(如c语言)好。 print("hello world")2.Bug,Debug 多看,多思考,多尝试、查资料、记录 3.prin…...
ioremap_nocache函数
ioremap_nocache 是 Linux 内核中用于将物理地址映射到内核虚拟地址空间的函数,特别是用于 I/O 内存映射,并且禁用缓存。 一、基本语法 void __iomem *ioremap_nocache(phys_addr_t phys_addr, size_t size); 二、基本功能 将物理内存地址映射到内核虚拟…...
【235. 二叉搜索树的最近公共祖先 中等】
题目: 给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个结点 p、q,最近公共祖先表示为一个结点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一…...
构建智能企业:中关村科金大模型企业知识库的技术解析与应用
在数字化转型的浪潮中,企业对智能化知识管理的需求日益增长。知识作为企业的核心资产,其高效管理和应用对于提升企业运营效率和决策质量至关重要。中关村科金大模型企业知识库凭借其强大的技术架构和广泛的应用场景,成为构建智能企业的重要工…...
C++进阶——用Hash封装unordered_map和unordered_set
目录 前言 源码怎么说 为什么要兼容? 兼容的具体做法? 为什么要把Key转为整数(HashFcn)? 模拟实现 一、建立框架 二、迭代器 运算符重载 迭代器兼容大法 三、[ ]重载 四、实现不能修改key 实现及测试代码 …...
b612相机 13.5.5解锁会员hook
工具 lspatch(点击选最新版本下载) shizuku(点击选最新版本下载) SimpleHook(点击选最新版本下载) b612(自行百度下载) 效果图 教程 [{"packageName":"com.camp…...
iOS - 弱引用表(Weak Reference Table)
1. 基本数据结构 // 弱引用表的基本结构 struct weak_table_t {weak_entry_t *weak_entries; // 保存所有的弱引用对象size_t num_entries; // 当前存储的弱引用数量uintptr_t mask; // 哈希表大小掩码uintptr_t max_hash_displacement; /…...
C#语言的网络编程
C#语言的网络编程 引言 随着互联网的飞速发展,网络编程成为了软件开发中的一个重要领域。C#语言作为一种现代编程语言,凭借其丰富的类库、良好的可读性和强大的功能,广泛应用于开发各种网络应用程序。无论是Windows应用、Web应用还是云服务…...
【操作系统】课程 4调度与死锁 同步测练 章节测验
4.1知识点导图 处理机调度与死锁相关内容的文字整理: 基本准则 资源利用率:使系统中的处理机和其他所有资源都尽可能地保持忙碌状态。系统吞吐量:单位时间内系统所完成的作业数。公平性:使各进程都获得合理的CPU时间,而…...
如何查看已经安装的python版本和相关路径信息
如何查看已经安装的python版本和相关路径信息 本文目录: 一、通过命令行模式查询 1、通过命令where python 2、通过命令print(sys.executable) 二、在 Anaconda Navigator 中 三、只安装python的环境下 一、通过命令行模式查询 同时按windowR键,输入cmd&#x…...
设计模式-结构型-适配器模式
在软件开发中,随着系统的不断扩展和模块的不断增加,往往会遇到不同模块之间接口不兼容的情况。此时,如果我们能通过某种方式将一个接口转化为另一个接口,那么开发工作将变得更加灵活和高效。适配器模式(Adapter Patter…...
鸿蒙操作系统(HarmonyOS)
鸿蒙操作系统(HarmonyOS)是华为公司推出的一款面向未来、面向全场景的分布式操作系统。它旨在为用户提供一个更加智能、便捷和安全的操作环境,支持多种终端设备之间的无缝协作。在鸿蒙应用开发中,ArkUI作为官方推荐的用户界面开发…...
基于海思soc的智能产品开发(camera sensor的两种接口)
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 对于嵌入式开发设备来说,除了图像显示,图像输入也是很重要的一部分。说到图像输入,就不得不提到camera。目前ca…...
解密LLM结构化输出:代码示例与原理分析
解密LLM结构化输出:代码示例与原理分析 一、LLM结构化输出概述 1. 结构化输出的定义与优势 结构化输出指的是语言模型(LLM)生成的遵循特定格式(如JSON、XML)的数据,这些数据易于解析和处理。相较于非结构…...
Go语言的数据类型
Go语言的数据类型详解 Go语言是一门具有简洁、高效并且强类型的编程语言。它的设计理念之一是让程序员能够以清晰、简明的方式表达自己的意图。在Go语言中,数据类型是其基础构建块之一,理解不同数据类型的特点和使用场景对于编写高效的Go程序至关重要。…...
复杂园区网基本分支的构建
目录 1、各主机进行网络配置。2、交换机配置。3、配置路由交换,进行测试。4、配置路由器接口和静态路由,进行测试。5、最后测试任意两台主机通信情况 模拟环境链接 拓扑结构 说明: VLAN标签在上面的一定是GigabitEthernet接口的,…...
如何很快将文件转换成另外一种编码格式?编码?按指定编码格式编译?如何检测文件编码格式?Java .class文件编码和JVM运行期内存编码?
如何很快将文件转换成另外一种编码格式? 利用VS Code右下角的"选择编码"功能,选择"通过编码保存"可以很方便将文件转换成另外一种编码格式。尤其,在测试w/ BOM或w/o BOM, 或者ANSI编码和UTF编码转换,特别方便。VS文件另…...
《C++11》Lambda 匿名函数从入门到进阶 优缺点分析 示例
Lambda 匿名函数从入门到进阶 C11 引入了 lambda 表达式,这是一种非常强大的功能,可以让我们在代码中定义匿名函数。它们不仅使代码更加简洁,而且在处理回调、算法和多线程编程时极为方便。本文将带你从入门到进阶,全面了解 C11 …...
STM32 HardFault调试实战:用Keil的Call Stack快速定位崩溃代码
STM32 HardFault调试实战:用Keil的Call Stack快速定位崩溃代码 嵌入式开发中,HardFault异常就像一位不速之客,总是在最不合时宜的时刻出现。当你的STM32程序突然"跑飞",最终停在HardFault_Handler的死循环中时ÿ…...
Cursor Pro破解工具:从设备限制到永久免费使用的完整指南
Cursor Pro破解工具:从设备限制到永久免费使用的完整指南 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your …...
Janus-Pro-7B开源镜像价值:支持LoRA微调,适配垂直领域图文任务
Janus-Pro-7B开源镜像价值:支持LoRA微调,适配垂直领域图文任务 Janus-Pro-7B是一个统一的多模态理解与生成AI模型,能够同时处理图像理解和文本到图像的生成任务。这个7.42B参数规模的模型在单一架构中实现了视觉问答、图像描述、OCR识别和文…...
10个Illustrator脚本工具:彻底改变你的设计工作流程
10个Illustrator脚本工具:彻底改变你的设计工作流程 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 你是否厌倦了在Adobe Illustrator中重复执行繁琐的操作?…...
终极指南:用scrapy-pinduoduo快速获取拼多多电商数据
终极指南:用scrapy-pinduoduo快速获取拼多多电商数据 【免费下载链接】scrapy-pinduoduo 拼多多爬虫,抓取拼多多热销商品信息和评论 项目地址: https://gitcode.com/gh_mirrors/sc/scrapy-pinduoduo 在电商数据驱动的时代,获取拼多多平…...
**量化模型实战:用Python构建高精度股票收益预测模型(附完整代码)**在金融工程领域,**量化投资**已成为主流策略之一。本
量化模型实战:用Python构建高精度股票收益预测模型(附完整代码) 在金融工程领域,量化投资已成为主流策略之一。本文将带你从零开始构建一个基于时间序列特征的股票收益预测模型,使用Python实现,并结合真实…...
Realistic Vision V5.1 虚拟摄影棚实战:基于SpringBoot的AI图像生成API服务
Realistic Vision V5.1 虚拟摄影棚实战:基于SpringBoot的AI图像生成API服务 最近有不少做电商或者内容平台的朋友跟我聊,说他们想给自家的产品加个AI生成图片的功能,比如让用户输入一段描述,就能自动生成商品主图或者营销海报。想…...
SAP Fiori开发避坑指南:OData V2和V4到底怎么选?从项目实战角度聊聊
SAP Fiori开发实战:OData V2与V4选型决策框架 当技术评审会的投影仪亮起,会议室里十几位开发骨干的目光聚焦在PPT最后一页的决策点上——这个即将投入千万预算的S/4HANA转型项目,究竟该采用OData V2还是V4作为服务协议?作为经历过…...
微信小程序集成企业微信客服的完整开发指南
1. 为什么需要在小程序集成企业微信客服 每次看到用户在小程序里转来转去找不到客服入口,我都替他们着急。去年我们团队接手一个电商小程序项目时,就遇到过这样的尴尬——30%的用户投诉都集中在"找不到人咨询"这个问题上。后来接入企业微信客服…...
第二章:LangChain Core 深度剖析 —— Runnable 协议与基础抽象
系列专栏:深入 LangChain —— 从核心原理到生产实践 本章目标:理解 Runnable 作为 LangChain 通用执行协议的设计思想;掌握 LCEL(LangChain Expression Language)的组合模式;熟悉 langchain-core 中的核心抽象层次。 2.1 引言:为什么要从 Core 读起? 如果你只是使用 …...
