---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IO开发S</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------
java_枚举
为什么要有枚举?
问题:
要定义星期几或性别的变量,该怎么定义?假设用1-7分别表示星期一到星期日,但有人可能会写成int weekday = 0;或即使使用常量方式也无法阻止意外。
枚举就是要让某个类型的变量的取值只能为若干个固定值中的一个,否则,编译器就会报错。枚举可以让编译器在编译时就可以控制源程序中填写的非法值,普通变量的方式在开发阶段无法实现这一目标。
用普通类如何实现枚举功能,定义一个Weekday的类来模拟枚举功能。
私有的构造方法
每个元素分别用一个公有的静态成员变量表示
可以有若干公有方法或抽象方法。采用抽象方法定义nextDay就将大量的if.else语句转移成了一个个独立的类。
示例:
- package cn.itcast.day01;
- public abstract class WeekDay1 {
- private WeekDay1(){};
- public final static WeekDay1 Mon=new WeekDay1(){
- @Override
- public WeekDay1 nexDay() {
- // TODO Auto-generated method stub
- return Tue;
- }};
- public final static WeekDay1 Tue=new WeekDay1(){
- @Override
- public WeekDay1 nexDay() {
- // TODO Auto-generated method stub
- return Mon;
- }};
- // public WeekDay nexDay(){
- // if(this==Mon){
- // return Tue;
- // }else{
- // return Mon;
- // }
- //
- // }
- public abstract WeekDay1 nexDay();
- public String toString(){
- return this==Mon?"Mon":"Tue";
- }
- }
枚举的基本应用
举例:定义一个Weekday的枚举。
扩展:枚举类的values,valueOf,name,toString,ordinal等方法
//打印调用枚举的
System.out.println(weekDay1);
//打印调用枚举的名字.和上一个基本一样
System.out.println(weekDay1.name());
//打印调用枚举中成员所在的位置
System.out.println(weekDay1.ordinal());
//把字符串变成枚举对应的元素.
System.out.println(WeekDay.valueOf("SUN").toString());
//将枚举变成数组.可以便利里面的元素.
System.out.println(WeekDay.values().length);
总结:
枚举是一种特殊的类,其中的每个元素都是该类的一个实例对象,例如可以调用WeekDay.SUN.getClass().getName和WeekDay.class.getName()。
枚举的高级应用
枚举就相当于一个类,其中也可以定义构造方法、成员变量、普通方法和抽象方法。
枚举元素必须位于枚举体中的最开始部分,枚举元素列表的后要有分号与其他成员分隔。把枚举中的成员方法或变量等放在枚举元素的前面,编译器报告错误。
带构造方法的枚举
>构造方法必须定义成私有的
>如果有多个构造方法,该如何选择哪个构造方法?
>枚举元素MON和MON()的效果一样,都是调用默认的构造方法。
示例:
- public enum WeekDay{
- SUN,MON,TUE,WED(1),THI,FRI,SAT;
- //注意:
- //1.构造方法.必须放在元素列表之后,
- //2.如果元素列表后面有东西的话.元素列表后面一定要要分号;
- //3.定义枚举的构造方法.一定要被私有修饰
- //4.在枚举后面加上()大话号.就表示.创建这个元素指向实例对象的时候使用哪个构造方法.
- private WeekDay(){
- System.out.println("first");
- }
- private WeekDay(int day){
- System.out.println("second");
- }
- }
带抽象方法的枚举
>定义枚举TrafficLamp
>实现普通的next方法
>实现抽象的next方法:每个元素分别是由枚举类的子类来生成的实例对象,这些子类采用类似内部类的方式进行定义。
>增加上表示时间的构造方法
示例:
- //交通灯枚举(带有抽象方法)
- public enum TrafficLamp{
- //实现父类的方法用内部类,并传递给构造函数一个值
- REDLAMP(30){
- public TrafficLamp nextLamp(){
- return GRRMLAMP;
- }
- },
- //实现父类的方法用内部类,并传递给构造函数一个值
- GRRMLAMP(30){
- public TrafficLamp nextLamp(){
- return YELLOWLAMP;
- }
- },
- //实现父类的方法用内部类,并传递给构造函数一个值
- YELLOWLAMP(5){
- public TrafficLamp nextLamp(){
- return REDLAMP;
- }
- };
- //要是共有的,因为子类要实现.抽象方法.需要子类是实现,
- public abstract TrafficLamp nextLamp();
- //定义私有变量
- private int timp;
- //建立构造函数.谁调用就赋值给谁
- private TrafficLamp(int timp){
- this.timp=timp;
- }
- }
---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IO开发S</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------