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