EnumMap是Java中专为枚举类型设计的高效Map实现,内部基于数组存储,键必须为同一枚举类型的非null值,迭代顺序与枚举常量声明顺序一致。示例中使用OrderStatus枚举作为键,将各状态映射到对应提示信息,通过静态代码块初始化EnumMap实例,实现快速查找。其优势在于性能优于HashMap、内存更节省、天然有序,适用于状态机、策略分发等场景,构造时需传入枚举类对象。

在Java中,EnumMap 是一种专为枚举类型设计的高性能Map实现。它要求键(key)必须是枚举类型,内部通过数组存储,因此效率高且迭代顺序固定为枚举常量的声明顺序。
创建和使用EnumMap的基本步骤
定义一个枚举类型作为键,然后创建对应的EnumMap实例来存储键值对。
- EnumMap不能包含null键,但可以有null值
- 所有键必须来自同一个枚举类型
- Map的遍历顺序与枚举常量的定义顺序一致
示例:用EnumMap管理状态处理器
假设有一个表示订单状态的枚举,我们希望将每个状态映射到对应的操作逻辑。
enum OrderStatus {
PENDING,
SHIPPED,
DELIVERED,
CANCELLED
}
public class OrderProcessor {
private static final EnumMap statusMessages =
new EnumMap<>(OrderStatus.class);
static {
statusMessages.put(OrderStatus.PENDING, "订单正在处理中");
statusMessages.put(OrderStatus.SHIPPED, "订单已发货");
statusMessages.put(OrderStatus.DELIVERED, "订单已送达");
statusMessages.put(OrderStatus.CANCELLED, "订单已取消");
}
public static String getMessage(OrderStatus status) {
return statusMessages.get(status);
}
}
EnumMap的优势和适用场景
由于其内部基于数组索引,性能优于HashMap,特别适合枚举作为键的配置类数据。
立即学习“Java免费学习笔记(深入)”;
- 比HashMap更节省内存,访问速度更快
- 天然有序,按枚举声明顺序排列
- 适用于状态机、配置映射、策略分发等场景










