JDK 1.5 之前需要自定义枚举类

JDK 1.5 新增的enum关键字用于定义枚举类

若枚举只有一个成员,则可以作为一种单例模式的实现方式。

枚举类型是指由一组固定的常量组成合法值的类型,枚举提供了编译时的类型安全,枚举类型还允许添加任意的方法和域,并实现任意的接口。

Java枚举类型背后的基本想法非常简单:她们就是通过共有的静态final域为每个枚举常量导出实际的类。因为没有可以访问的构造器,所以枚举类型是真正的final。

先看一个自定义枚举类的代码:

 

package com.liu.enumtest;

 class Season{
	private Season(String seasonName ,String seansonDesc){
		this.seasonName=seasonName;
		this.seansonDesc=seansonDesc;
	}
	//final变量要立即初始化或者构造函数初始化
	private final String seasonName;
	private final String seansonDesc;
	//3.通过公共的方法调用属性,只能调出来get方法。
	public String getSeasonName() {
		return seasonName;
	}
	public String getSeansonDesc() {
		return seansonDesc;
	}
	//4.创建枚举类的对象
	public static final Season SPRING=new Season("春天","春心荡漾");
	public static final Season SUMMER=new Season("夏天","热死人了");
	public static final Season AUTUMN=new Season("秋天","秋高气爽");
	public static final Season WINTER=new Season("冬天","冰天雪地");
	@Override
	public String toString() {
		return "Season [seasonName=" + seasonName + ", seansonDesc=" + seansonDesc + "]";
	}
	
	public void show(){
		System.out.println("这是一个季节");
	}
}
public class TestSeason {

	public static void main(String[] args) {
		Season spring = Season.SPRING;
		System.out.println(spring);
		spring.show();
		
	}

}

运行结果:

 

Season [seasonName=春天, seansonDesc=春心荡漾]
这是一个季节

 

使用enum关键字定义枚举类

 

package com.liu.enum2;

interface Info{
<span style="white-space:pre">	</span>void show();
}


enum Season implements Info{
	//一旦为枚举类定义了带参数的构造方法后,列举枚举就必须对应的传入参数
	//同时必须要放在最前面
	SPRING("spring","春心荡漾"),
	SUMMER("夏天","热死人了"),
	//可以让不同的枚举类的对象重写抽象方法
	AUTUMN("秋天","秋高气爽"){
		@Override
		public void show() {
			System.out.println("分手在那个秋天");
		}
	},
	WINTER("冬天","冰天雪地");
	//不能用public修饰
	private Season(String seasonName ,String seansonDesc){
		this.seasonName=seasonName;
		this.seansonDesc=seansonDesc;
	}
	//final变量要立即初始化或者构造函数初始化
	private final String seasonName;
	private final String seansonDesc;
	//3.通过公共的方法调用属性,只能调出来get方法。
	public String getSeasonName() {
		return seasonName;
	}
	public String getSeansonDesc() {
		return seansonDesc;
	}
	
	@Override
	public String toString() {
		return "Season [seasonName=" + seasonName + ", seansonDesc=" + seansonDesc + "]";
	}
	@Override
	public void show() {
		System.out.println("这是一个季节");
	}
	
	
}

public class TestSeason {

	public static void main(String[] args) {
		
		Season spring=Season.SPRING;
		spring.show();
		//1.values方法 以数组形式返回每个枚举对象
		Season[]seasons=Season.values();
		for (int i = 0; i < seasons.length; i++) {
			System.out.println(seasons[i]);
		}
		//
		String summer ="SUMMER";
		Season sea=Season.valueOf(Season.class, summer);
		System.out.println(sea);
		//线程的状态是一个枚举类,可以打印出这6个状态
		Thread.State[] states=Thread.State.values();
		for(int i=0;i<states.length;i++){
			System.out.println(states[i]);
		}
		Season autumn=Season.AUTUMN;
		autumn.show();
		
	}

}

 

 

 

运行结果:

这是一个季节
Season [seasonName=spring, seansonDesc=春心荡漾]
Season [seasonName=夏天, seansonDesc=热死人了]
Season [seasonName=秋天, seansonDesc=秋高气爽]
Season [seasonName=冬天, seansonDesc=冰天雪地]
Season [seasonName=夏天, seansonDesc=热死人了]
NEW
RUNNABLE
BLOCKED
WAITING
TIMED_WAITING
TERMINATED
分手在那个秋天

另外在项目中也经常这样使用

public enum Type {
    MANAGER(1, "管理员"),
    USER(1, "普通用户");
    private Integer value;
    private String desc;

    Type(Integer value, String desc) {
        this.value = value;
        this.desc = desc;
    }

    public Integer getValue() {
        return value;
    }

    public void setValue(Integer value) {
        this.value = value;
    }

    public String getDesc() {
        return desc;
    }

    public void setDesc(String desc) {
        this.desc = desc;
    }

    private static Map<Integer, Type> valueStore = new HashMap<>();
    private static Map<String, Type> descStore = new HashMap<>();

    static {
        Type[] types = Type.values();
        for (Type type : types) {
            valueStore.put(type.getValue(), type);
            descStore.put(type.getDesc(), type);
        }
    }

    public static Type valueof(Integer value) {
        return valueStore.get(value);
    }

    public static Type descof(String desc) {
        return descStore.get(desc);
    }

}

使用枚举实现单例模式:

1

 

package com.liu.enum2;

enum Singleton{
	INSTANCE;
}

public class SingletonTest {
	public static void main(String[] args) {
		Singleton s=Singleton.INSTANCE;
		Singleton s2=Singleton.INSTANCE;
		System.out.println(s==s2);
	}
}

2

 

 

package com.liu.enum2;

enum Singleton2{
	INSTANCE{
		@Override
		protected void read() {
			System.out.println("read");
		}

		@Override
		protected void write() {
			System.out.println("write");
		}
	};
	protected abstract void read();
	protected abstract void write();
}
public class SingletonTest2 {

	public static void main(String[] args) {
		Singleton2 s=Singleton2.INSTANCE;
		s.read();
	}

}

反编译过后还原的类

 

 

 

 

public abstract class Singleton extends Enum
{

    private Singleton(String s, int i)
    {
        super(s, i);
    }

    protected abstract void read();

    protected abstract void write();

    public static Singleton[] values()
    {
        Singleton asingleton[];
        int i;
        Singleton asingleton1[];
        System.arraycopy(asingleton = ENUM$VALUES, 0, asingleton1 = new Singleton[i = asingleton.length], 0, i);
        return asingleton1;
    }

    public static Singleton valueOf(String s)
    {
        return (Singleton)Enum.valueOf(singleton/Singleton, s);
    }

    Singleton(String s, int i, Singleton singleton)
    {
        this(s, i);
    }

    public static final Singleton INSTANCE;
    private static final Singleton ENUM$VALUES[];

    static 
    {
        INSTANCE = new Singleton("INSTANCE", 0) {

            protected void read()
            {
                System.out.println("read");
            }

            protected void write()
            {
                System.out.println("write");
            }

        };
        ENUM$VALUES = (new Singleton[] {
            INSTANCE
        });
    }
}