EnumMap是Java中基于数组实现的高性能枚举映射,提供O(1)存取速度、有序遍历且键必须为同一枚举类型实例,不可为null;可通过put/get操作管理键值对,并能替代if-else或switch实现清晰的策略映射,如用Operation枚举关联运算符函数;注意其非线程安全,需通过Collections.synchronizedMap包装用于多线程环境。

EnumMap 是 Java 中专为枚举类型设计的高性能 Map 实现,它内部使用数组存储,保证了快速的存取速度和有序性。由于其特性,EnumMap 在处理与枚举相关的键值映射时非常高效且安全。
EnumMap 的基本使用方法
EnumMap 的构造函数要求传入枚举类型,所有键必须是同一枚举类型的实例。创建后,可以像普通 Map 一样进行 put、get、remove 等操作。
示例:
public enum Day {MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY
}
EnumMap
schedule.put(Day.MONDAY, "Work on project");
schedule.put(Day.TUESDAY, "Team meeting");
System.out.println(schedule.get(Day.MONDAY)); // 输出:Work on project
注意:不能使用 null 作为键,但可以将 null 作为值存储。
立即学习“Java免费学习笔记(深入)”;
利用 EnumMap 替代条件判断
在很多场景中,可以用 EnumMap 来替代 if-else 或 switch 结构,使代码更清晰、可维护性更强。
例如,定义不同操作对应的处理器:
public enum Operation {ADD, SUBTRACT, MULTIPLY, DIVIDE
}
Map
{
opMap.put(Operation.ADD, (a, b) -> a + b);
opMap.put(Operation.SUBTRACT, (a, b) -> a - b);
opMap.put(Operation.MULTIPLY, (a, b) -> a * b);
opMap.put(Operation.DIVIDE, (a, b) -> a / b);
}
int result = opMap.get(Operation.ADD).apply(5, 3); // 得到 8
这种方式避免了冗长的分支语句,逻辑集中且易于扩展。
EnumMap 的性能优势与线程安全
EnumMap 内部基于数组实现,索引由枚举的 ordinal() 值决定,因此访问时间复杂度为 O(1),比 HashMap 更快,且遍历时保持枚举声明顺序。
说明:
- 所有 key 必须来自同一个枚举类,否则抛出 ClassCastException。
- 不支持 key 为 null,put(null, value) 会抛出 NullPointerException。
- EnumMap 不是线程安全的,若在多线程环境中使用,需外部同步控制,如使用 Collections.synchronizedMap。
示例同步包装:
EnumMapMap
基本上就这些。用好 EnumMap 能让枚举相关的映射逻辑更简洁、高效。










