1、 case 3 : /返回蓝色对象 return BLUE ; default: /错误的值 return null ;public class ColorDemo public static void main(String args) Color c1 = Color.RED ; /取得红色 System.out.println(c1.getName();/输出名字 Color c2 = Color.getInstance(3) ;/根据编号取得名字 System.out.println(c2.getName();输出:红色蓝色程序将Color类中的构造方法私有,之后在类中准备了若干个实例
2、化对象,以后如果要取得Color类的实例,则只能从RED、GREEN、BLUE3个对象中取得,这样就有效地限制了对象 的取得范围。以上使用的Color对象指定的范围,是通过一个个常量对每个对象进行编号的。也就是说,一个个的对象就相当于用常量表示了,所以,按照这个思路也可以直接使用一个接口规定出一组常量的范围。使用接口表示一组范围。public interface Colorpublic static final int RED = 1 ; /表示红色public static final int GREEN = 2 ; /表示绿色public static final int BLUE = 3
3、 ; /表示蓝色以上表示出的各个颜色是通过接口指定好的常量范围,与之前相比更加简单。但是这样做也会存在另外一个问题,如果现在使用如下的代码:public class ColorDemo System.out.println(Color.RED + Color.GREEN) ; /颜色相加3两个颜色的常量相加后形成“3”,这样的结果看起来会令人很困惑,操作很不明确。二、定义一个枚举类型定义一个Color的枚举类型public enum Color /定义枚举类型RED,GREEN,BLUE ; /定义枚举的3个类型以上的Color定义出来的枚举类型,其中包含RED,GREEN,BLUE3个数据。
4、可以使用“枚举.variable”的形式取出枚举中的指定内容。取出一个枚举的内容public class GetEnumContent Color c = Color.BLUE ; /取出蓝色 System.out.println(c); /输出信息BLUE枚举类型的数据也可以使用“枚举.values()”的形式,将全部的枚举类型变为对象数组的形式,之后直接使用foreach进行输出。使用foreach输出枚举内容public class PrintDemo for(Color c : Color.values() /枚举.values()表示得到 全部枚举的内容REDGREEN枚举中的每个
5、类型也可以使用switch进行判断,但在switch语句中使用枚举类型时,一定不能在每一个枚举类型值的前面加上枚举类型的类名(如Color.BlUE),否则编译器将会报错。使用switch进行判断public class SwitchPrintDemo print(c);public static void print(Color color) switch(color) /判断每个颜色 case RED: /直接判断枚举内容 System.out.println(红颜色); break ; case GREEN:绿颜色 case BLUE:蓝颜色 default : /未知内容未知颜色红颜色
6、绿颜色蓝颜色上面的Color.values()方法表示取得枚举中的全部内容,返回的是一个对象数组,这是枚举本身支持的一个方法,除了这个方法之外到底还有哪些方法可以供开发者使用呢?三、Enum使用Enum关键字定义一个枚举,实际上此关键字表示的是java.lang.Enum类型,即使用enum声明的枚举类型就相当于定义一个类,而此类则默认继承java.lang.Enum类。java.lang.Enum类的定义如下:public abstract class EnumE extends Enumextends Objectimplements Comparable, Serializable从En
7、um类的定义中可以清楚地发现,此类实现了Comparable和Serializable两个接口,证明枚举类型可以使用比较器和序列化操作。 枚举类的主要操作方法protected Enum(String name,int ordinal)构造 接收枚举的名称和枚举的常量创建枚举对象protected final Object clone()throws CloneNotSupportedException克隆枚举对象public final int compareTo(E o)对象比较public final boolean equals(Object other)比较两个枚举对象public
8、final int hashCode()返回枚举常量的哈希码public final String name()返回此枚举的名称public final int ordinal()返回枚举常量的序数public static T extends EnumT valueOf(Class + c.name();0 - RED1 - GREEN2 - BLUE从结果中发现Enum类自动为枚举中的每个元素进行编号,而且下标从0开始。四、为每一个枚举对象属性赋值1、通过构造方法为属性赋值每个枚举类中都 有其指定好的若干对象,当然,每一个枚举对象中也可以包含多个属性。而这些属性 也可以通过构造方法为其赋值
9、。通过构造方法为枚举属性赋值enum ColorRED(),GREEN(),BLUE(private Color(String name)public String getName() return name ;public void setName(String name) this.name = name ;public class ConstructorEnum for(Color c:Color.values() System.out.println(c.ordinal() + + c.name()( + c.getName() + ) RED(红色) GREEN(绿色) BLUE(蓝
10、色)以上程序代码在定义的Color枚举类中设置了一个name属性,并且通过构造方法设置name属性的内容。因为Color中已经明确地写出有一个参数的构造方法,所以在声明枚举内容时就必须调用这个构造方法,这样在定义枚举内容的就必须使用如下语句:2、通过setter方法为属性赋值以上是通过构造方法的方式为属性赋值的,当然也可以通过调用setter()的方式为指定的属性赋值。但是这样一来就必须明确每一个枚举类的对象,如果操作的对象是RED,则名字应该为“红色”;如果操作的是GREEN,则名字应该为“绿色”等。使用setName()设置内容RED,GREEN,BLUE; switch(this) /判
11、断是否是紅色 if(.equals(name) else设置内容错误。 public class SetEnum c.setName(兰色 /设置一个错误的名字 /设置一个正确的名字 System.out.println(c.getName();以上代码中首先通过枚举取得了一个对象。之后开始为其设置内容,一开始设置了一个不符合要求的内容,所以会出现“设置内容错误”的提示;而如果设置的内容正确,则可以直接将其赋值给name属性。如果不想通过“枚举类.对象”的形式取得每一个枚举类对象,也可以使用Enum类定义的“枚举类.valueof()”方法的形式进行调用。使用valueof()方法找到一个枚举
12、对象。public class ValueOfEnum Color c = Enum.valueOf(Color.class, BLUE以上操作代码使用valueof(),但是在设置第一个参数时使用了“枚举.class”的形式,此为Java的反射机制。五、使用比较器在Enum类的定义中已经实现好了Comparable接口,所以枚举类的内容本身是可以进行排序的,下面通过TreeSet演示枚举的排序操作。在类集部分曾经介绍过TreeSet可以直接进行排序,排序的规则是通过Comparable接口完成的。验证枚举比较器import java.util.Iterator;import java.uti
13、l.Set;import java.util.TreeSet;public class ComparableEnum Set t = new TreeSet() ; t.add(Color.GREEN) ; t.add(Color.BLUE) ; t.add(Color.RED) ; Iterator iter = t.iterator() ; while(iter.hasNext() System.out.print(iter.next() + 、RED、GREEN、BLUE、以上代码中数据加入的顺序是GREEN、BLUE、RED,但是输出之后的顺序是RED、GREEN、BLUE证明已经被排
14、序了,是使用Enum类中的ordinal属性排序的。六、类集对枚举的支持EnumMap、EnumSet1、EnumMapEnumMap是Map接口的子类,所以本身还是以Map的形式进行操作,即key-value。如果要使用EnumMap,则首先要创建EnumMap的对象,在创建此对象时必须指定要操作的枚举类型,构造方法如下:public EnumMap(Class keyType)验证EnumMapimport java.util.EnumMap;import java.util.Map; Map desc = null ; desc = new EnumMap + desc.get(c);=
15、 输出全部键值 =desc.keySet() /取得全部的key System.out.print(c.name() + ); System.out.println();= 输出全部的内容 = for(String s:desc.values() /取得全部的value System.out.print(s + = 输出全部内容 =RED-GREEN-绿色BLUE-= 输出全部键值 = 输出全部的内容 =红色、绿色、蓝色、2、EnumSetEnumSet是Set接口的子类,所以里面的内容是无法重复的。使用EnumSet时不能直接使用关键字new为其进行实例化,所以在此类中提供了很多的静态方法,
16、如表: EnumSetallOf(ClasselementType) 将枚举中的全部内容设置到EnumSet中of(E first,E. rest) 创建一个包含枚举指定内容的EnumSet对象copyOf(Collectionc) 创建一个从指定Collection中指定的EnumSet对象ComplementOf(EnumSets)创建一个其元素类型与指定枚举set相同的枚举set,最初包含指定集合中所不包含的此类型的所有元素noneOf(Class 创建一个可以接收指定类的空集合验证EnumSet将全部的集合设置到EnumSet集合中import java.util.EnumSet; E
17、numSet es = null ; /声明一个EnumSet对象= EnumSet.allOf(Color.Class) = es = EnumSet.allOf(Color.class) ; /将枚举的全部类型设置到EnumSet对象中 print(es) ;public static void print(EnumSet temp)temp) System.out.print(c + = EnumSet.allOf(Color.Class) =以上程序使用EnumSet提供的static方法allOf(),将一个枚举中的全部内容设置到EnumSet集合中。验证EnumSet只设置一个枚举的类型到集合中= EnumSet.al
copyright@ 2008-2023 冰点文库 网站版权所有
经营许可证编号:鄂ICP备19020893号-2