Java集合详解:List、Set、Map使用指南
时间:2026-04-11 17:52:32 181浏览 收藏
本文深入解析Java集合框架中List、Set、Map三大核心接口的本质与实战要点:强调它们均为抽象契约,必须通过ArrayList、HashSet、HashMap等具体实现类实例化;厘清add()、put()等看似相似方法背后截然不同的语义逻辑——List追加/插入、Set去重返回布尔结果、Map覆盖键值并返回旧值;警示遍历时修改集合的正确姿势(务必使用Iterator.remove())及Map遍历的性能优化技巧(优先entrySet());特别指出自定义类作为Map键时,hashCode()和equals()重写的必要性与常见陷阱,帮助开发者避开高发运行时bug。

Java里List、Set、Map不是接口就是抽象契约
它们本身不能直接 new,必须用实现类。比如写 new List() 会编译报错——因为 List 是接口;同理 Set 和 Map 也是。常见写法是:
List→ 实际用ArrayList()或LinkedList()Set→ 实际用HashSet()(无序)、TreeSet()(有序)或LinkedHashSet()(插入顺序)Map→ 实际用HashMap()(最常用)、TreeMap()(按 key 排序)、LinkedHashMap()(保持插入/访问顺序)
别在声明时就写死实现类名(如 ArrayList list = new ArrayList()),这会削弱多态性和可替换性。
add()、put()、add():三个集合的“添加”行为完全不同
名字相似但语义差异大,容易混淆导致逻辑错误:
List.add()总是追加到末尾(list.add("a")),也可指定索引插入(list.add(0, "x"))Set.add()有去重逻辑:返回boolean,true表示新增成功,false表示该元素已存在(不抛异常,也不覆盖)Map.put()是“键值对”操作:如果 key 已存在,会用新 value 覆盖旧 value,并返回旧 value;若 key 不存在,返回null
Setset = new HashSet<>(); System.out.println(set.add("hello")); // true System.out.println(set.add("hello")); // false Map map = new HashMap<>(); System.out.println(map.put("count", 1)); // null System.out.println(map.put("count", 2)); // 1(被覆盖的旧值)
遍历 List/Map 最安全的写法是增强 for + 迭代器
直接用普通 for 循环遍历 List 没问题,但修改集合内容(如 remove())时容易 ConcurrentModificationException;Map 的 keySet() 或 entrySet() 遍历时也一样。
- 想边遍历边删元素?必须用
Iterator.remove() - 遍历
Map优先用entrySet(),比keySet()+get()少一次哈希查找 forEach()方法(Java 8+)简洁,但内部仍是迭代器,不能在 lambda 里修改集合结构
Listlist = new ArrayList<>(Arrays.asList("a", "b", "c")); Iterator it = list.iterator(); while (it.hasNext()) { String s = it.next(); if ("b".equals(s)) it.remove(); // 安全删除 } Map map = new HashMap<>(); map.forEach((k, v) -> System.out.println(k + "=" + v)); // 只读,不能 put/remove
HashMap 的 key 必须正确重写 hashCode() 和 equals()
这是运行时 bug 高发区:如果你自定义类作 Map 的 key,但没重写这两个方法,哪怕两个对象逻辑相等,get() 也会返回 null。
hashCode()决定对象存进哪个桶(bucket),不一致 → 找不到桶 → 直接 missequals()在桶内做精确比对,不一致 → 桶里有对象但判为不等 → 仍 miss- IDE(如 IntelliJ)可自动生成这两个方法,但要注意字段是否都参与比较——比如 ID 字段变更是不是该影响相等性?
String、Integer 等 JDK 类已内置可靠实现,放心用;但 new Object() 或自定义 POJO 作 key 时,这点绝不能跳过。
今天关于《Java集合详解:List、Set、Map使用指南》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
455 收藏
-
文章 · java教程 | 4天前 | hashmap · 集合 · Java教程 · hashCode · equals · java HashMap map equals hashCode 可变key474 收藏
-
178 收藏
-
文章 · java教程 | 5天前 | map · 并发安全 · 缓存设计 · Java教程 · java optional concurrenthashmap computeIfAbsent Map缓存236 收藏
-
204 收藏
-
文章 · java教程 | 6天前 | Java · 集合 · ArrayList · Iterator · removeIf · java iterator ArrayList ConcurrentModificationException removeIf410 收藏
-
文章 · java教程 | 6天前 | Java · 异步编程 · 后端开发 · CompletableFuture · 接口聚合 · java 结果合并 completablefuture 并行调用 超时兜底428 收藏
-
文章 · java教程 | 6天前 | Java · 线程安全 · DateTimeFormatter · 日期处理 · 并发问题 · java 线程安全 日期格式化 threadlocal SimpleDateFormat DateTimeFormatter481 收藏
-
224 收藏
-
文章 · java教程 | 1星期前 | 时间处理 · instant · Java教程 · 时区转换 · DateTimeFormatter · java DateTimeFormatter java.time 时区处理 ZoneId INSTANT461 收藏
-
文章 · java教程 | 1星期前 | Java · Stream · 集合统计 · 分组聚合 · Collectors · java Stream Collectors groupingBy counting summarizingInt478 收藏
-
文章 · java教程 | 1星期前 | Java · 文件读取 · 异常处理 · 资源管理 · try-with-resources · java 异常处理 try-with-resources 资源关闭 AutoCloseable 文件流268 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习