一、枚举概述
创建枚举类型要使用 enum 关键字,隐含了所创建的类型都是 java.lang.Enum 类的子类(java.lang.Enum 是一个抽象类)。枚举类型符合通用模式 Class Enum<E extends Enum<E>>
,而 E
表示枚举类型的名称。枚举类型的每一个值都将映射到 protected Enum(String name, int ordinal)
构造函数中,在这里,每个值的名称都被转换成一个字符串,并且序数设置表示了此设置被创建的顺序。
二、枚举的常用方法
返回类型 | 方法名称 | 方法说明 |
---|---|---|
int | compareTo(E o) | 比较此枚举与指定对象的顺序 |
boolean | equals(Object other) | 当指定对象等于此枚举常量时,返回 true。 |
Class<?> | getDeclaringClass() | 返回与此枚举常量的枚举类型相对应的 Class 对象 |
String | name() | 返回此枚举常量的名称,在其枚举声明中对其进行声明 |
int | ordinal() | 返回枚举常量的序数(它在枚举声明中的位置,其中初始常量序数为零) |
String | toString() | 返回枚举常量的名称,它包含在声明中 |
static<T extends Enum<T>> T | static valueOf(Class<T> enumType, String name) | 返回带指定名称的指定枚举类型的枚举常量。 |
方法介绍:
ordinal()
方法,该方法获取的是枚举变量在枚举类中声明的顺序,下标从0开始,如日期中的MONDAY在第一个位置,那么MONDAY的ordinal值就是0,如果MONDAY的声明位置发生变化,那么ordinal方法获取到的值也随之变化,注意在大多数情况下我们都不应该首先使用该方法,毕竟它总是变幻莫测的。compareTo(E o)
方法则是比较枚举的大小,注意其内部实现是根据每个枚举的ordinal值大小进行比较的。name()
方法与toString()
几乎是等同的,都是输出变量的字符串形式。至于valueOf(Class<T> enumType, String name)
方法则是根据枚举类的Class对象和枚举名称获取枚举常量,注意该方法是静态的,在枚举单例时会用到。
三、枚举实现接口demo
由于枚举类型默认继承Enum抽象类,由于java语言的单继承特性,因此枚举类型无法再继承其它类,但可以实现接口。
下面的的demo,大家看起来会觉得这不专业,字里行间透漏着非专业的气氛,你们猜对了,轻喷。
接口
package com.alex.benum;
public interface Do {
void protect();
void encourage();
}
枚举类型
package com.alex.benum;
public enum Role implements Do {
Angel("cuteCat","need you,my guardian"){
@Override
public void protect() {
System.out.println(super.getName()+": "+super.getWord()+".");
}
@Override
public void encourage() {
System.out.println(super.getName()+
": my guardian,i hope the kiss will give you more courageous.");
}
},
Guardian("robot","my angel,i hope to guard you all my life"){
@Override
public void protect() {
System.out.println(super.getName()+": "+super.getWord()+".");
}
@Override
public void encourage() {
System.out.println(super.getName()+
": thanks for the courageous you give me,i will treasure them all my life.");
}
};
private String name;
private String word;
private Role(String name,String word) {
this.name = name;
this.word = word;
}
public String getName() {
return name;
}
public String getWord() {
return word;
}
@Override
public void protect() {
}
@Override
public void encourage() {
}
}
测试类
package com.alex.benum;
public class MyMain {
public static void main(String[] args) {
Role angel = Role.Angel;
Role guardian = Role.Guardian;
angel.protect();
guardian.protect();
angel.encourage();
guardian.encourage();
}
}
执行结果
cuteCat: need you,my guardian.
robot: my angel,i hope to guard you all my life.
cuteCat: my guardian,i hope the kiss will give you more courageous.
robot: thanks for the courageous you give me,i will treasure them all my life.
四、说明
4.1 每一个枚举值都是一个实例,默认是空参构造,如果你需要带参构造实例,则需要定义相应构造方法。
4.2 枚举实现接口的方法都是public修饰,这是由于接口默认是public修饰,子类重写的方法访问权限要大于等于父类(接口)。
4.3 枚举值中重写的是枚举类型的方法,枚举类型的方法是对于接口的抽象方法的重写。