Map是Java中存储键值对的核心接口,提供put、get、remove等方法,键唯一值可重复,常见实现有HashMap(高性能无序)、LinkedHashMap(有序)、TreeMap(按键排序)、Hashtable(线程安全但过时)和ConcurrentHashMap(高并发推荐),遍历推荐entrySet方式。
Map 是 Java 中用于存储键值对(key-value)的核心接口,它属于 Java 集合框架的一部分。与 List 和 Set 不同,Map 不是 Collection 的子接口,但它在实际开发中使用非常广泛,比如缓存、配置管理、数据映射等场景。
Map 接口定义了将键映射到值的对象集合,其中每个键最多只能对应一个值。也就是说,键是唯一的,但值可以重复。常见方法包括:
理解 Map 的关键是记住“通过键找值”,而不是像 List 那样通过索引访问。
Java 提供了多个 Map 接口的实现类,适用于不同场景。以下是常用的几种:
HashMap基于哈希表实现,是最常用的 Map 实现。它的查找、插入和删除操作平均时间复杂度为 O(1)。但不保证元素的顺序,尤其是随着容量扩容可能会重新散列。
继承自 HashMap,内部维护了一个双向链表来保持插入顺序(或访问顺序)。因此它可以按插入顺序遍历元素。
基于红黑树实现,能够对键进行自然排序或自定义比较器排序。
早期的同步 Map 实现,类似 HashMap,但方法加了 synchronized 关键字,线程安全。
专为高并发设计的线程安全 Map,采用分段锁或 CAS 操作(JDK 8 后优化为 Node 数组 + volatile + CAS/synchronized)。
选择哪个 Map 实现取决于具体需求:
→ 使用 HashMap
最有效的方式是通过 entrySet() 遍历键值对:
Mapmap = new HashMap<>(); map.put("a", 1); map.put("b", 2); for (Map.Entry entry : map.entrySet()) { System.out.println(entry.getKey() + " -> " + entry.getValue()); }
也可以分别遍历 keySet() 或 values(),但若同时需要键和值,entrySet 更高效。
基本上就这些。掌握 Map 的核心在于理解“键唯一、值可重复”以及不同实现类的底层结构和适用场景。实际使用时结合性能、线程安全和顺序要求做出合理选择即可。