[url]http://www.cnblogs.com/Fskjb/archive/2009/08/03/1537917.html[/url]
public class TestEnum {
/*最普通的枚举*/
public enum ColorSelect {
red, green, yellow, blue;
}
/* 枚举也可以象一般的类一样添加方法和属性,你可以为它添加静态和非静态的属性或方法,这一切都象你在一般的类中做的那样. */
public enum Season {
// 枚举列表必须写在最前面,否则编译出错
winter, spring, summer, fall;
private final static String location = "Phoenix";
public static Season getBest() {
if (location.equals("Phoenix"))
return winter;
else
return summer;
}
}
/*还可以有构造方法*/
public enum Temp {
/*通过括号赋值,而且必须有带参构造器和一属性跟方法,否则编译出错
* 赋值必须是都赋值或都不赋值,不能一部分赋值一部分不赋值
* 如果不赋值则不能写构造器,赋值编译也出错*/
absoluteZero(-459), freezing(32),boiling(212), paperBurns(451);
private final int value;
public int getValue() {
return value;
}
//构造器默认也只能是private, 从而保证构造函数只能在内部使用
Temp(int value) {
this.value = value;
}
}
public static void main(String[] args) {
/*
* 枚举类型是一种类型,用于定义变量,以限制变量的赋值 赋值时通过"枚举名.值"来取得相关枚举中的值
*/
ColorSelect m = ColorSelect.blue;
switch (m) {
/*注意:枚举重写了ToString(),说以枚举变量的值是不带前缀的
*所以为blue而非ColorSelect.blue
*/
case red:
System.out.println("color is red");
break;
case green:
System.out.println("color is green");
break;
case yellow:
System.out.println("color is yellow");
break;
case blue:
System.out.println("color is blue");
break;
}
System.out.println("遍历ColorSelect中的值");
/*通过values()获得枚举值的数组*/
for (ColorSelect c : ColorSelect.values()) {
System.out.println(c);
}
System.out.println("枚举ColorSelect中的值有:"+ColorSelect.values().length+"个");
/*ordinal()返回枚举值在枚举中的索引位置,从0开始*/
System.out.println(ColorSelect.red.ordinal());//0
System.out.println(ColorSelect.green.ordinal());//1
System.out.println(ColorSelect.yellow.ordinal());//2
System.out.println(ColorSelect.blue.ordinal());//3
/*枚举默认实现了java.lang.Comparable接口*/
System.out.println(ColorSelect.red.compareTo(ColorSelect.green));
System.out.println(Season.getBest());
for(Temp t:Temp.values()){
/*通过getValue()取得相关枚举的值*/
System.out.println(t+"的值是"+t.getValue());
}
}
}
---------------------------------------------------------------------------------
本文转自:http://blog.sina.com.cn/s/blog_44c1e6da0100bia5.html
1.创建一个最简单的枚举类型
创建枚举类型要使用enum关键字,隐含了所创建的类型都是java.lang.Enum类的子类,它是抽象类。其中,枚举类型符合通用模式 Class Enum<E extends Enum<E>>,而 E 表示枚举类型的名称。枚举类型的每一个值都将映射到 protected Enum(String name, int ordinal) 构造函数中,在这里,每个值的名称都被转换成一个字符串,并且序数设置表示了此设置被创建的顺序。
public enum Size{
SMALL,
MEDIUM,
LARGE;
}
实际上调用了三次构造函数:
new Enum<Size>("SMALL",0);
new Enum<Size>("MEDIUM",1);
new Enum<Size>("LARGE",2);
值的名字和顺序值可以分别通过name()/toString()、ordinal()获得。
自建的枚举类除了继承Enum类的方法外还会自动获得两个方法values()和valueOf(String name)。不需要自己定义就可以直接使用。这其中的原理我不太清楚,麻烦明白的人给我讲讲。
values()可以用来遍历枚举类中的值,valueOf(String name)可以用来通过名字获得具体的枚举值。
获得枚举类值的方法:有三种方式,具体见代码。
public class MostSimpleEnum {
public enum Size{
SMALL,
MEDIUM,
LARGE;
}
public static void main(String[] args){
//两种获得枚举类型的方法
Size s1 = Size.SMALL;
Size s2 = Enum.valueOf(Size.class, "SMALL");
Size s3 = Size.valueOf("MEDIUM");//1
//直接使用‘=’来比较两个枚举类型是否相等
if(Size.LARGE == Enum.valueOf(Size.class, "LARGE")){
System.out.println("Size.LARGE == Enum.valueOf(Size.class, \"LARGE\")");
}
//结果同上,枚举重载了equals方法,但比较方法同上
System.out.println("Size.MEDIUM.equals(Enum.valueOf(Size.class, \"MEDIUM\")):"+
Size.MEDIUM.equals(Enum.valueOf(Size.class, "MEDIUM")));
//遍历枚举类型中所有的成员
for(Size s:Size.values()){//2
//1.定义的序号 2.定义的名称 3.在Enum中被重载,同name()
System.out.println(s.ordinal()+" "+s.name()+" "+s.toString());
}
//分析在抽象类Enum中没有定义的两个方法values()和valuesOf()的来历
analyzeEnum(s1);
//定义的枚举类默认继承的抽象类java.lang.Enum
//有两个特殊的方法,我们并没有定义,结果却显示来自我们自定定义的类
//前面都已经使用过的,1.valueOf(String name),2.values()
//枚举类自动包括这两个事先被定义好的方法
System.out.println("获得"+s3);
}
public static void analyzeEnum(Enum e){
System.out.println("class:"+e.getClass().getName());
System.out.println("declear class:"+e.getClass().getDeclaringClass());
System.out.println("super class:"+e.getClass().getSuperclass().getName());
Class<?>[] interfaces = e.getClass().getInterfaces();
for(Class c:interfaces){
System.out.println("implement interdace:"+c.getName());
}
Method[] methods = e.getClass().getMethods();
for(Method m:methods){
System.out.println("mehtods:"+m.getName()+" from:"+m.getDeclaringClass());
}
}
}
2.创建一个复杂点的枚举类Week,在这个枚举类中我们为它添加自己定义的成员、构造器、方法。
注意虽然在Enum中有构造器,但是我们无法在自定义的枚举类中调用它,直接继承java.lang.Enum也是不允许的。我们自己定义的构造器只能被定义成private或者package-protected,同样在我们也无法调用这个自定义的狗构造器。
public enum Week {
//定义枚举类的值
Monday("MON","星期一"),
Tuesday("TUE","星期二"),
Wednesday("WED","星期三"),
Thursday("THU","星期四"),
Friday("FRI","星期五"),
Saturday("SAT","星期六"){
@Override
public boolean isRest(){
return true;
}
},
Sunday("SUN","星期日"){
@Override
public boolean isRest(){
return true;
}
};
private String abbreviation = "";//缩写
private String chineseName = "";//中文名字
//定义自己的构造器
private Week(String abbreviation,String chineseName){
this.abbreviation = abbreviation;
this.chineseName = chineseName;
}
public String abbreviation(){
return abbreviation;
}
public String getChineseName(){
return chineseName;
}
//周六和周日应该返回true,此方法在周六和周日的值中被重载
public boolean isRest(){
return false;
}
//重载,对它进行稍稍的改动
@Override
public String toString(){
return this.getClass().getName()+"."+this.name();
}
}
//测试Week
public class WeekTest {
public static void main(String[] args){
for(Week week:Week.values()){
System.out.println("-----------------------------------------");
System.out.println("ordinal():"+week.ordinal());
System.out.println("name():"+week.name());
System.out.println("getChineseName():"+week.getChineseName());
System.out.println("abbreviation():"+week.abbreviation());
System.out.println("isRest():"+week.isRest());
System.out.println("toString():"+week);
}
}
}
顺便说一下,继承或实现接口的方法和一般Java类是相同的。
public class TestEnum {
/*最普通的枚举*/
public enum ColorSelect {
red, green, yellow, blue;
}
/* 枚举也可以象一般的类一样添加方法和属性,你可以为它添加静态和非静态的属性或方法,这一切都象你在一般的类中做的那样. */
public enum Season {
// 枚举列表必须写在最前面,否则编译出错
winter, spring, summer, fall;
private final static String location = "Phoenix";
public static Season getBest() {
if (location.equals("Phoenix"))
return winter;
else
return summer;
}
}
/*还可以有构造方法*/
public enum Temp {
/*通过括号赋值,而且必须有带参构造器和一属性跟方法,否则编译出错
* 赋值必须是都赋值或都不赋值,不能一部分赋值一部分不赋值
* 如果不赋值则不能写构造器,赋值编译也出错*/
absoluteZero(-459), freezing(32),boiling(212), paperBurns(451);
private final int value;
public int getValue() {
return value;
}
//构造器默认也只能是private, 从而保证构造函数只能在内部使用
Temp(int value) {
this.value = value;
}
}
public static void main(String[] args) {
/*
* 枚举类型是一种类型,用于定义变量,以限制变量的赋值 赋值时通过"枚举名.值"来取得相关枚举中的值
*/
ColorSelect m = ColorSelect.blue;
switch (m) {
/*注意:枚举重写了ToString(),说以枚举变量的值是不带前缀的
*所以为blue而非ColorSelect.blue
*/
case red:
System.out.println("color is red");
break;
case green:
System.out.println("color is green");
break;
case yellow:
System.out.println("color is yellow");
break;
case blue:
System.out.println("color is blue");
break;
}
System.out.println("遍历ColorSelect中的值");
/*通过values()获得枚举值的数组*/
for (ColorSelect c : ColorSelect.values()) {
System.out.println(c);
}
System.out.println("枚举ColorSelect中的值有:"+ColorSelect.values().length+"个");
/*ordinal()返回枚举值在枚举中的索引位置,从0开始*/
System.out.println(ColorSelect.red.ordinal());//0
System.out.println(ColorSelect.green.ordinal());//1
System.out.println(ColorSelect.yellow.ordinal());//2
System.out.println(ColorSelect.blue.ordinal());//3
/*枚举默认实现了java.lang.Comparable接口*/
System.out.println(ColorSelect.red.compareTo(ColorSelect.green));
System.out.println(Season.getBest());
for(Temp t:Temp.values()){
/*通过getValue()取得相关枚举的值*/
System.out.println(t+"的值是"+t.getValue());
}
}
}
---------------------------------------------------------------------------------
本文转自:http://blog.sina.com.cn/s/blog_44c1e6da0100bia5.html
1.创建一个最简单的枚举类型
创建枚举类型要使用enum关键字,隐含了所创建的类型都是java.lang.Enum类的子类,它是抽象类。其中,枚举类型符合通用模式 Class Enum<E extends Enum<E>>,而 E 表示枚举类型的名称。枚举类型的每一个值都将映射到 protected Enum(String name, int ordinal) 构造函数中,在这里,每个值的名称都被转换成一个字符串,并且序数设置表示了此设置被创建的顺序。
public enum Size{
SMALL,
MEDIUM,
LARGE;
}
实际上调用了三次构造函数:
new Enum<Size>("SMALL",0);
new Enum<Size>("MEDIUM",1);
new Enum<Size>("LARGE",2);
值的名字和顺序值可以分别通过name()/toString()、ordinal()获得。
自建的枚举类除了继承Enum类的方法外还会自动获得两个方法values()和valueOf(String name)。不需要自己定义就可以直接使用。这其中的原理我不太清楚,麻烦明白的人给我讲讲。
values()可以用来遍历枚举类中的值,valueOf(String name)可以用来通过名字获得具体的枚举值。
获得枚举类值的方法:有三种方式,具体见代码。
public class MostSimpleEnum {
public enum Size{
SMALL,
MEDIUM,
LARGE;
}
public static void main(String[] args){
//两种获得枚举类型的方法
Size s1 = Size.SMALL;
Size s2 = Enum.valueOf(Size.class, "SMALL");
Size s3 = Size.valueOf("MEDIUM");//1
//直接使用‘=’来比较两个枚举类型是否相等
if(Size.LARGE == Enum.valueOf(Size.class, "LARGE")){
System.out.println("Size.LARGE == Enum.valueOf(Size.class, \"LARGE\")");
}
//结果同上,枚举重载了equals方法,但比较方法同上
System.out.println("Size.MEDIUM.equals(Enum.valueOf(Size.class, \"MEDIUM\")):"+
Size.MEDIUM.equals(Enum.valueOf(Size.class, "MEDIUM")));
//遍历枚举类型中所有的成员
for(Size s:Size.values()){//2
//1.定义的序号 2.定义的名称 3.在Enum中被重载,同name()
System.out.println(s.ordinal()+" "+s.name()+" "+s.toString());
}
//分析在抽象类Enum中没有定义的两个方法values()和valuesOf()的来历
analyzeEnum(s1);
//定义的枚举类默认继承的抽象类java.lang.Enum
//有两个特殊的方法,我们并没有定义,结果却显示来自我们自定定义的类
//前面都已经使用过的,1.valueOf(String name),2.values()
//枚举类自动包括这两个事先被定义好的方法
System.out.println("获得"+s3);
}
public static void analyzeEnum(Enum e){
System.out.println("class:"+e.getClass().getName());
System.out.println("declear class:"+e.getClass().getDeclaringClass());
System.out.println("super class:"+e.getClass().getSuperclass().getName());
Class<?>[] interfaces = e.getClass().getInterfaces();
for(Class c:interfaces){
System.out.println("implement interdace:"+c.getName());
}
Method[] methods = e.getClass().getMethods();
for(Method m:methods){
System.out.println("mehtods:"+m.getName()+" from:"+m.getDeclaringClass());
}
}
}
2.创建一个复杂点的枚举类Week,在这个枚举类中我们为它添加自己定义的成员、构造器、方法。
注意虽然在Enum中有构造器,但是我们无法在自定义的枚举类中调用它,直接继承java.lang.Enum也是不允许的。我们自己定义的构造器只能被定义成private或者package-protected,同样在我们也无法调用这个自定义的狗构造器。
public enum Week {
//定义枚举类的值
Monday("MON","星期一"),
Tuesday("TUE","星期二"),
Wednesday("WED","星期三"),
Thursday("THU","星期四"),
Friday("FRI","星期五"),
Saturday("SAT","星期六"){
@Override
public boolean isRest(){
return true;
}
},
Sunday("SUN","星期日"){
@Override
public boolean isRest(){
return true;
}
};
private String abbreviation = "";//缩写
private String chineseName = "";//中文名字
//定义自己的构造器
private Week(String abbreviation,String chineseName){
this.abbreviation = abbreviation;
this.chineseName = chineseName;
}
public String abbreviation(){
return abbreviation;
}
public String getChineseName(){
return chineseName;
}
//周六和周日应该返回true,此方法在周六和周日的值中被重载
public boolean isRest(){
return false;
}
//重载,对它进行稍稍的改动
@Override
public String toString(){
return this.getClass().getName()+"."+this.name();
}
}
//测试Week
public class WeekTest {
public static void main(String[] args){
for(Week week:Week.values()){
System.out.println("-----------------------------------------");
System.out.println("ordinal():"+week.ordinal());
System.out.println("name():"+week.name());
System.out.println("getChineseName():"+week.getChineseName());
System.out.println("abbreviation():"+week.abbreviation());
System.out.println("isRest():"+week.isRest());
System.out.println("toString():"+week);
}
}
}
顺便说一下,继承或实现接口的方法和一般Java类是相同的。