EnumSet是Java中专为枚举设计的高性能集合,基于位向量实现,内存紧凑、操作高效,支持allOf、noneOf、of、range等静态方法创建,保证元素按枚举声明顺序存储,适用于频繁增删查场景,但不支持null值且非线程安全。

在Java中,EnumSet 是专门用于处理枚举类型的高性能集合类,它提供了一种紧凑且高效的方式来存储和操作枚举常量。相比普通的 Set 实现(如 HashSet),EnumSet 使用位向量实现,性能更优,内存占用更低,且保证元素按定义顺序排列。
创建 EnumSet 的常用方式
假设我们有如下枚举类型:
// 枚举类型示例enum Color {
RED, GREEN, BLUE, YELLOW, BLACK
}
可以通过多种静态方法创建 EnumSet:
- EnumSet.allOf(Class):包含枚举中所有常量 EnumSet
- EnumSet.noneOf(Class):创建空集合 EnumSet
- EnumSet.of(E...):添加指定的枚举值 EnumSet
- EnumSet.range(from, to):包含从 from 到 to(闭区间)之间的所有枚举值(要求枚举按顺序定义) EnumSet
操作 EnumSet 集合
EnumSet 支持标准的集合操作,例如添加、删除、判断包含等,但由于其内部优化,这些操作非常高效。
立即学习“Java免费学习笔记(深入)”;
EnumSet
colors.add(Color.YELLOW);
colors.remove(Color.RED);
colors.contains(Color.YELLOW); // true
colors.size(); // 1
也可以进行集合运算:
// 并集colors.addAll(EnumSet.of(Color.BLACK));
// 交集
colors.retainAll(EnumSet.of(Color.YELLOW, Color.BLACK));
// 差集
colors.removeAll(EnumSet.of(Color.BLACK));
遍历 EnumSet
由于 EnumSet 保持枚举的自然顺序(即声明顺序),遍历时结果是有序的。
System.out.println(c);
}
也可结合 lambda 表达式使用:
colors.forEach(System.out::println);注意事项与最佳实践
-
只能用于枚举类型:传入非枚举类会抛出
ClassCastException -
不允许 null 值:调用
add(null)会抛出NullPointerException - 线程不安全:如有并发需求,需手动同步
- 性能优势明显:尤其适合需要频繁增删查的枚举集合场景










