news 2026/4/14 22:59:30

玩转Java Map集合,从基础到实战的全面解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
玩转Java Map集合,从基础到实战的全面解析

在Java集合框架中,Map是与Collection并列的核心接口,它以**键值对(Key-Value)**的形式存储数据,是开发中处理映射关系的必备工具。不管是日常业务开发中的数据缓存、配置存储,还是复杂的业务逻辑映射,Map都能发挥关键作用。今天就带大家从基础到实战,彻底搞懂Map集合的使用!

一、Map集合的核心特性

1. 键的唯一性:Map中的Key是唯一的,不能重复,若插入相同Key的键值对,新的Value会覆盖旧值。

2. 值的可重复性:Value可以重复,多个Key可以对应同一个Value。

3. 无序/有序特性:不同实现类的有序性不同,如HashMap无序,LinkedHashMap按插入顺序排序,TreeMap按Key的自然顺序排序。

二、Map的常用实现类

实现类 特点 适用场景

HashMap 基于哈希表实现,线程不安全,查询效率高(O(1)),无序 单线程环境下的常规映射存储

Hashtable 基于哈希表实现,线程安全(方法加synchronized),效率低,无序 多线程环境(已被ConcurrentHashMap替代)

LinkedHashMap 继承HashMap,维护插入/访问顺序,查询效率接近HashMap 需要保留数据插入顺序的场景

TreeMap 基于红黑树实现,按Key自然排序/自定义排序,查询效率O(logn) 需要对Key进行排序的场景

ConcurrentHashMap 分段锁/CAS实现线程安全,并发性能优于Hashtable 高并发环境下的映射存储

三、Map集合的核心操作

以最常用的HashMap为例,演示基础CRUD操作:

java

import java.util.HashMap;

import java.util.Map;

import java.util.Set;

public class MapDemo {

public static void main(String[] args) {

// 1. 创建Map集合

Map<String, Integer> studentScore = new HashMap<>();

// 2. 新增键值对

studentScore.put("张三", 90);

studentScore.put("李四", 85);

studentScore.put("王五", 95);

// 重复Key,Value会被覆盖

studentScore.put("张三", 92);

// 3. 获取值

int zhangSanScore = studentScore.get("张三");

System.out.println("张三的成绩:" + zhangSanScore); // 输出92

// 4. 遍历Map

// 方式1:遍历Key集

Set<String> keys = studentScore.keySet();

for (String key : keys) {

System.out.println(key + ":" + studentScore.get(key));

}

// 方式2:遍历Entry集(推荐,效率更高)

for (Map.Entry<String, Integer> entry : studentScore.entrySet()) {

System.out.println(entry.getKey() + ":" + entry.getValue());

}

// 5. 删除键值对

studentScore.remove("李四");

System.out.println("删除李四后:" + studentScore);

// 6. 判断是否包含Key/Value

boolean hasWangWu = studentScore.containsKey("王五");

boolean has85 = studentScore.containsValue(85);

System.out.println("是否包含王五:" + hasWangWu); // true

System.out.println("是否包含85分:" + has85); // false

}

}

四、Map的实战技巧

1. 避免空指针:使用 getOrDefault() 方法,当Key不存在时返回默认值,替代直接 get() 。

java

int score = studentScore.getOrDefault("赵六", 0); // 赵六不存在,返回0

2. JDK8+新特性:使用 putIfAbsent() 避免覆盖已有值, computeIfAbsent() 懒加载创建值。

java

// 仅当Key不存在时才插入

studentScore.putIfAbsent("赵六", 88);

// 若Key不存在,通过函数生成值并插入

studentScore.computeIfAbsent("钱七", k -> 78);

3. 排序Map:借助TreeMap或Stream对HashMap进行排序。

java

// 按Key升序排序

Map<String, Integer> sortedMap = new TreeMap<>(studentScore);

// 按Value降序排序(Stream方式)

studentScore.entrySet().stream()

.sorted(Map.Entry.<String, Integer>comparingByValue().reversed())

.forEach(System.out::println);

五、注意事项

1. HashMap的Key要求:Key的类必须重写 hashCode() 和 equals() ,否则会导致重复Key或查询失效。

2. 线程安全问题:HashMap非线程安全,多线程环境下若同时进行增删改,需使用ConcurrentHashMap或手动加锁。

3. 性能考量:HashMap初始容量和负载因子需合理设置(默认初始容量16,负载因子0.75),避免频繁扩容。

Map集合是Java开发中高频使用的工具,掌握其不同实现类的特性和实战技巧,能大幅提升代码的效率和健壮性。你在使用Map时遇到过哪些问题?欢迎在评论区交流~

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

【C/C++】C语言内存函数

memcpy使用和模拟实现memcpy可以代替strcpy代码语言&#xff1a;javascriptAI代码解释void * memcpy ( void * destination, const void * source, size_t num );//void*来接受任意指针,size_t 单位是字节 //memcpy的头文件为<string.h> mem是memory的缩写 是内存的意思…

作者头像 李华
网站建设 2026/4/13 11:00:49

【C/C++】字符函数和字符串函数

字符函数和字符串函数1.字符分类函数C语⾔中有⼀系列的函数是专⻔做字符分类的&#xff0c;也就是⼀个字符是属于什么类型的字符的。 这些函数的使⽤都需要包含⼀个头⽂件是 ctype.h在这里插入图片描述这些函数的使⽤⽅法⾮常类似&#xff0c;我们就讲解⼀个函数的事情&#xf…

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

【C/C++】深入理解指针(一)

1.1 内存在讲内存和地址之前&#xff0c;我们想有个⽣活中的案例&#xff1a; 假设有⼀栋宿舍楼&#xff0c;把你放在楼⾥&#xff0c;楼上有100个房间&#xff0c;但是房间没有编号&#xff0c;你的⼀个朋友来找你玩&#xff0c; 如果想找到你&#xff0c;就得挨个房⼦去找&am…

作者头像 李华
网站建设 2026/4/14 15:09:39

PyTorch-CUDA-v2.6镜像部署Flask API对外提供模型服务

PyTorch-CUDA-v2.6 镜像部署 Flask API 对外提供模型服务 在深度学习模型从实验室走向生产环境的过程中&#xff0c;一个常见但棘手的问题是&#xff1a;为什么训练好的模型一到线上就“水土不服”&#xff1f; 可能是依赖版本不一致、GPU 环境缺失、CUDA 编译失败&#xff0c;…

作者头像 李华
网站建设 2026/4/15 12:09:46

CSS3 新增文本属性

一、文本阴影二、文本换行三、文本溢出四、文本修饰

作者头像 李华