EnumSet的元素必须是枚举类型,EnumSet集合也是有序的,起顺序就是Enum类定义的顺序。java
EnumSet没有构造函数函数
EnumSet的complementOf(EnumSet), 返回没有包含在集合中的元素,看源码以及下面的例子。性能
package com.example.demo; import java.util.EnumSet; enum Season { SPRING, SUMMER, FALL, WINTER } public class EnumSetDemo { public static void main(String[] args) { // 用元素对象的类型来初始化一个EnumSet集合,即Season.class EnumSet es1 = EnumSet.allOf(Season.class); System.out.println("es1: "+ es1); // 初始化一个空的EnumSet集合 EnumSet es2 = EnumSet.noneOf(Season.class); es2.add(Season.SUMMER); es2.add(Season.SPRING); System.out.println("es2: "+ es2); // 初始化一个带参数的EnumSet集合 EnumSet es3 = EnumSet.of(Season.WINTER, Season.SPRING, Season.SUMMER); System.out.println("es3: "+ es3); // 初始化一个从第一个元素到最后一个元素的集合, 不能从枚举中最后一个到第一个。 EnumSet es4 = EnumSet.range(Season.SUMMER, Season.WINTER); System.out.println("es4: "+ es4); // 初始化一个集合中剩下的元素 EnumSet es5 = EnumSet.complementOf(es2); System.out.println("es5: "+ es5); } }
运行结果:es5
es1: [SPRING, SUMMER, FALL, WINTER] es2: [SPRING, SUMMER] es3: [SPRING, SUMMER, WINTER] es4: [SUMMER, FALL, WINTER] es5: [FALL, WINTER]
Java 集合 Set 总结:code
HashSet比TreeSet性能好,由于它不须要维护元素的顺序。对象
LinkedHashSet须要用额外的链表维护元素的插入顺序,插入性能比HashSet低,但遍历性能高。源码
EnumSet元素性能最好,只能保存Enum类型,而且是有顺序的。class