0

0

Java集合框架中的Set与Map的应用场景

P粉602998670

P粉602998670

发布时间:2026-01-11 11:27:26

|

663人浏览过

|

来源于php中文网

原创

该用Set而非List当需自动去重且不关心顺序或索引;HashSet平均O(1)、LinkedHashSet保插入序、TreeSet支持排序但O(log n),注意null限制。

java集合框架中的set与map的应用场景

什么时候该用 Set 而不是 List

当你需要自动去重、且不关心元素顺序或索引访问时,Set 是更合适的选择。比如读取一批用户 ID 并统计唯一数量,用 List 后手动去重不仅慢(O(n²)),还容易漏掉边界情况。

  • HashSet 最常用:底层是哈希表,插入/查找平均 O(1),但不保证顺序
  • LinkedHashSet 适合需要按插入顺序遍历的场景,比如最近访问的资源缓存
  • TreeSet 用于需要自然排序或自定义排序的集合,比如排行榜分数去重后升序展示,但增删查是 O(log n)

注意:Set 不能存 nullTreeSet 直接抛 NullPointerExceptionHashSet 允许一个 null,但要小心后续比较逻辑)

Map 的键为什么必须是不可变对象

因为 Map(尤其是 HashMap)依赖键的 hashCode()equals() 定位和比较元素。如果键对象在放入后被修改,导致 hashCode() 变化,就再也找不到它了——不是丢失,是“藏起来了”。

  • 常见踩坑:用可变的 StringBuilder 或自定义类作键,没重写 hashCode()equals(),或重写了但字段参与计算后又被改
  • 安全做法:优先用 StringInteger 等不可变类型;若必须用自定义类,确保所有参与 hashCode()/equals() 的字段在构造后不可变

例如:

Map userScore = new HashMap<>();
userScore.put("alice", 95);
// 后续用 "alice" 能稳定取到,因为 String 不可变

SetMap 在实际业务中怎么配合用

很多场景下二者不是二选一,而是协同:用 Map 存主数据 + 关联关系,用 Set 做快速存在性判断或去重中间结果。

立即学习Java免费学习笔记(深入)”;

MoChat企业微信SCRM系统
MoChat企业微信SCRM系统

MoChat 是开源的企业微信应用开发框架&引擎,是一套通用的企业微信多租户SaaS管理系统,得益于 Swoole 和 Hyperf 框架的优秀,MoChat 可提供超高性能的同时,也保持着极其灵活的可扩展性。应用场景可用于电商、金融、零售、餐饮服装等服务行业的企业微信用户,通过简单的分流、引流转化微信客户为企业客户,结合强大的后台支持,灵活的运营模式,建立企业与客户的强联系,让企业的盈利

下载
  • 权限校验:把用户拥有的角色 ID 存进 HashSet,检查是否包含某个角色时用 roles.contains("ADMIN"),比遍历 List 快得多
  • 批量更新防重:从消息队列收到一批订单 ID,先塞进 Set 去重,再查 Map 批量加载已有订单,避免重复 DB 查询
  • 配置白名单:把合法的 API 路径存在 Set,拦截器里直接判断 if (!allowedPaths.contains(path)) reject();

性能关键点:别为了“看起来统一”而强行把 MapSet 用——语义不清,内存浪费,还可能因 null 值引发误判。

并发环境下选哪个实现

单线程用 HashSet/HashMap 没问题,但多线程写入必须换线程安全版本,否则会出错或死循环(JDK 7 的 HashMap 扩容时可能形成环形链表)。

  • 简单读多写少:用 Collections.synchronizedSet() / synchronizedMap(),但锁粒度大,吞吐低
  • 高并发读写:优先选 ConcurrentHashMap;它没有 ConcurrentHashSet,但可用 ConcurrentHashMap.newKeySet()(JDK 8+)替代
  • 注意:ConcurrentHashMapsize() 不是精确值(为避免锁竞争而妥协),需精确计数建议用 LongAdder 单独维护

最容易被忽略的是:即使用了 ConcurrentHashMap,复合操作如“检查不存在再 put”仍需 computeIfAbsent()putIfAbsent(),否则仍有竞态。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

831

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

737

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

396

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

80

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.4万人学习

C# 教程
C# 教程

共94课时 | 6.4万人学习

Java 教程
Java 教程

共578课时 | 44.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号