枚举就是一个对象,这个对象也包括子类对象的。下面通过两段代码体会一下枚举的使用吧:
(1)一个相对简单的枚举:
public enum ColorEnum {
RED,
GREEN,
BLUE;
public static void main(String[] args) {
// 获得枚举实例序号
int index = RED.ordinal();RED.compareTo(RED);
// 返回所有的枚举实例
ColorEnum[] colors = ColorEnum.values();
// 获得实例的名称
String colorName = GREEN.name();
// 通过实例名称来获得枚举实例
ColorEnum color = ColorEnum.valueOf(colorName);
/* 比较两个枚举的方法一
* 比较方式是比较枚举的ordinal
*/
int compare = BLUE.compareTo(BLUE);
/* 比较两个枚举的方法二
* 枚举支持直接用这种逻辑表达式方式作比较
*/
boolean isEqual = RED == GREEN;
// 枚举支持直接用switch作选择
switch (BLUE) {
case RED: break;
case GREEN: break;
case BLUE: break;
default: break;
}
}
}
(2)一个不那么简单的枚举:
import java.awt.Color;
import java.io.Serializable;
/**
* 颜色的枚举
* 是能实现接口
* 不能继承
* @author
*/
public enum ColorEnum implements Serializable {
/**
* 红色
*/
RED(255, 0, 0) {
public void doSomeThing() {
System.out.println(name());
}
},
/**
* 绿色
*/
GREEN(0, 255, 0) {
public void doSomeThing() {
System.out.println(ordinal());
}
},
/**
* 蓝色
*/
BLUE(0, 0, 255) {
@Override
public void doSomeThing() {
System.out.println(toString());
}
};
/**
* 颜色
*/
private Color color;
/**
* 实例化颜色枚举
* 枚举字段的实例化将会调用这个构造方法
* 必须用private修饰
* 代表只有本枚举自己能够构造
* 枚举的实例都是静态的
* 会在第一次访问的时候就生成
* @param r 红色
* @param g 绿色
* @param b 蓝色
*/
private ColorEnum(int r, int g, int b) {
this.color = new Color(r, g, b);;
}
/**
* @return 颜色实体
*/
public Color getColor() {
return color;
}
/**
* 定义抽象方法
* 实例必须实现它
*/
abstract void doSomeThing();
public static void main(String[] args) {
Color color = RED.getColor();
GREEN.doSomeThing();
}
} |