黑马程序员-高新技术-1枚举

 ---------------------- 
 ASP.Net+Android+IO开发S.Net培训、期待与您交流! ---------------------- 
 
day01-12 枚举的作用介绍
1. 枚举是这样一种特殊的类: 这个类一旦定义了, 就只能取,内部枚举列表里面声明了的那几个枚举类对象;(类似单例模式,只不过这里是多个限定元素)
2. 所有的枚举类对象都被定义在枚举类的枚举列表中, 生成枚举列表里面的元素时,可以是默认无参的 也可以是 有参的
3. 有参的枚举元素, 需要在类的内部自定义 枚举类的有参构造函数,注意此时定义了有参构造函数不会默认给出无参构造函数(和一般类一样)
4. 枚举类中一样可以定义方法,枚举元素(对象)一样可以调用这些方法
5. 原帖例子中定义了 抽象的方法, 所以, 这个枚举类本身是抽象的, 所以其枚举元素需要复写这些抽象的方法以实现实例化
6. 之所以, 用定义抽象方法再实例化的模式,是为了避免在一个方法内用switch来实现不同枚举元素的特定方法输出, 更符合OO原则,也方便维护
7. 所以,可以看出, 从构造函数,成员方法,成员变量的角度看,枚举类和普通的类基本没啥区别, 唯一的不同可能就是多了枚举元素列表限定了可实现对象
---------------------------------------------
day01-13 用普通类模拟枚举的实现原理 
为什么要有枚举
    问题:要定义星期几或性别的变量,该怎么定义?假设用1-7分别表示星期一到星期日,但有人可能会携程int week = 0;
    枚举就是要让每个类型的变量的取值只能为若干固定值中的一个,否则,编译器就会报错。
    枚举可以让编译器在编译时就可以控制源程序中填写的非法值,普通变量的方式在开发阶段无法实现这一目标
用普通类如何实现枚举功能,定义一个Weekday的类来模拟枚举功能。
    私有的构造方法;
    每个元素分别用一个公有的静态成员变量表示;
    可以有若干公有方法或抽象方法,例如,要提供nextDay方法必须是抽象的。采用抽象方法定义nextDay就将打啊两的if。else    
    语句转移成一个个独立的类。
枚举的基本引用
     举例:定义一个Weekday的枚举。
     扩展:枚举类的values,valueOf,name,toString,ordinal等方法
     总结:枚举是一种特殊的类,其中的每个元素都是该类的一个实例对象,例如可以调用WeekDay.SUN.getClass().getName()
        和 WeekDay.class.getName() 
为了大家更好地理解枚举先用普通类模仿一下枚举,这个可以参照java.awt.Color类
采用抽象方法定义nextDay就将大量  if else语句转移成了一个个独立的类。
如果想在一个类中编写完各个枚举类和测试调用类,那么可以将枚举类定义成调用类的内部类。
[java]  view plain copy
  1. package cn.itcast.day1;  
  2. //枚举的实现原理。  
  3. //第一种方式  
  4. public class WeekDay1 {  
  5.     private WeekDay1(){}  
  6.       
  7.     public final static WeekDay1 SUN = new WeekDay1();  
  8.     public final static WeekDay1 MON = new WeekDay1();  
  9.       
  10. //  第一种获取下一个元素方法  
  11.     public WeekDay1 nextDay(){  
  12.         if(this==SUN){  
  13.             return MON;  
  14.         }else{  
  15.             return SUN;  
  16.         }  
  17.     }  
  18.     public String toString(){  
  19.         return this==SUN?"SUN":"MON";  
  20.     }  
  21. }  
  22. /* 
  23. //通过匿名内部类的方式分别实现nextDay()方法。当方法抽象时类必须抽象。 
  24. public abstract class WeekDay1 { 
  25.     private WeekDay1(){} 
  26.     public final static WeekDay1 SUN = new WeekDay1(){ 
  27.         public WeekDay1 nextDay(){ 
  28.             return MON; 
  29.         } 
  30.     }; 
  31.     public final static WeekDay1 MON = new WeekDay1(){ 
  32.         public WeekDay1 nextDay(){ 
  33.             return SUN; 
  34.         } 
  35.     }; 
  36. //  第二种获取下一个元素方法 
  37.     public abstract WeekDay1 nextDay(); 
  38.     public String toString(){ 
  39.         return this==SUN?"SUN":"MON"; 
  40.     } 
  41. } 
  42. */  
---------------------------------
14 枚举的基本应用
[java]  view plain copy
  1. package cn.itcast.day1;  
  2.   
  3. public class EnumTest {  
  4.   
  5.     /** 
  6.      * @param args 
  7.      */  
  8.     public static void main(String[] args) {  
  9.         // TODO Auto-generated method stub  
  10.         WeekDay wd = WeekDay.SUN;  
  11.         System.out.println(wd.toString());  
  12.         System.out.println(wd.name());  
  13.         System.out.println(wd.ordinal());  
  14.         System.out.println(WeekDay.valueOf("wed".toUpperCase()));  
  15.         System.out.println("WeekDay.valueOf(\"MON\")::"+WeekDay.valueOf("MON"));  
  16.         System.out.println("WeekDay.valueOf(\"MON\")::"+WeekDay.values());  
  17.         WeekDay[] weekdays = WeekDay.values();  
  18.         for(WeekDay weekday : weekdays){  
  19.             System.out.println("返回weekday的元素"+weekday);  
  20.         }  
  21.     }  
  22.    public enum  WeekDay{  
  23.               
  24.             SUN(2),MON,TUE,WED,THI,FRI,SAT;  
  25.             //元素列表必须位于所有东西之前。所以构造方法要定义在元素后面,构造方法必须私有。  
  26.             private WeekDay(){System.out.println("first");}  
  27.             private WeekDay(int day){System.out.println("second");}  
  28.         }  
  29. }  
--------------------------------------------------- 
枚举类就相当于一个类,其中也可以定义构造方法、成员变量、普通方法和抽象方法。
枚举元素必须位于枚举体重的最开始部分,枚举元素列表的后面有分号与其他成员分隔。把枚举中的成员方法或
变量等放在枚举元素的前面,编译器报告错误。

带构造方法的枚举
    构造方法必须定义成私有的。
   如果有多个构造方法,该如何选择哪个构造方法?
   枚举元素MON和MON()的效果一样,都是调用默认的构造方法。
带方法的枚举
   定义枚举TrafficLamp
   实现普通的next方法
   实现抽象的next方法:每个元素分别是由枚举类的子类来生成的实例对象,这些子类采用类似内部类的方式进行定义。
   增加上表示时间的构造方法。
枚举只有一个成员时,就可以作为一种单例的实现方式。


[java] view plaincopy
  1. package cn.itcast.day1;  
  2. public class EnumTest {  
  3.   
  4.     /** 
  5.      * @param args 
  6.      */  
  7.     public static void main(String[] args) {  
  8.         TrafficLamp  tl = TrafficLamp.RED;  
  9.         System.out.println(tl);  
  10.         System.out.println(TrafficLamp.RED.nexLamp().toString());  
  11.           
  12.     }  
  13.  public enum TrafficLamp{  
  14.         //这里每个RED,GREEN和YELLOW都是实例对象,为了使用抽象方法,必须用RED去复写抽象方法。相当于子类覆盖。  
  15.         RED(50){  
  16.             public  TrafficLamp nexLamp(){  
  17.                 return GREEN;  
  18.             };  
  19.         },  
  20.         GREEN(40){  
  21.             public  TrafficLamp nexLamp(){  
  22.                 return YELLOW;  
  23.             }  
  24.         },  
  25.         YELLOW(10){  
  26.             public  TrafficLamp nexLamp(){  
  27.                 return RED;  
  28.             }  
  29.             };  
  30.           
  31.         public abstract TrafficLamp nexLamp();  
  32.         //定义成员变量设定每个元素的时间。通过父类构造函数 Private TrafficLamp设定时间。  
  33.         private int time;  
  34.         private TrafficLamp(int time){this.time=time;}  
  35.     }  
  36.     
  37. }                                                                                                  







[java]  view plain copy
  1. package cn.itcast.day1;  
  2. public class EnumTest {  
  3.   
  4.     /** 
  5.      * @param args 
  6.      */  
  7.     public static void main(String[] args) {  
  8.         TrafficLamp  tl = TrafficLamp.RED;  
  9.         System.out.println(tl);  
  10.         System.out.println(TrafficLamp.RED.nexLamp().toString());  
  11.           
  12.     }  
  13.  public enum TrafficLamp{  
  14.         //这里每个RED,GREEN和YELLOW都是实例对象,为了使用抽象方法,必须用RED去复写抽象方法。相当于子类覆盖。  
  15.         RED(50){  
  16.             public  TrafficLamp nexLamp(){  
  17.                 return GREEN;  
  18.             };  
  19.         },  
  20.         GREEN(40){  
  21.             public  TrafficLamp nexLamp(){  
  22.                 return YELLOW;  
  23.             }  
  24.         },  
  25.         YELLOW(10){  
  26.             public  TrafficLamp nexLamp(){  
  27.                 return RED;  
  28.             }  
  29.             };  
  30.           
  31.         public abstract TrafficLamp nexLamp();  
  32.         //定义成员变量设定每个元素的时间。通过父类构造函数 Private TrafficLamp设定时间。  
  33.         private int time;  
  34.         private TrafficLamp(int time){this.time=time;}  
  35.     }  
  36.     
  37. }                                                                                                  

----------------------ASP.Net+Android+IOS开发.Net培训、期待与您交流! ----------------------详细请查看:http://edu.csdn.net


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值