Java 集合 Set EnumSet

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

相关文章
相关标签/搜索