您的位置:首页 > 职场人生

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

2013-06-06 16:04 169 查看

---------------------- 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
plaincopy

package cn.itcast.day1;

//枚举的实现原理。

//第一种方式

public class WeekDay1 {

private WeekDay1(){}



public final static WeekDay1 SUN = new WeekDay1();

public final static WeekDay1 MON = new WeekDay1();



// 第一种获取下一个元素方法

public WeekDay1 nextDay(){

if(this==SUN){

return MON;

}else{

return SUN;

}

}

public String toString(){

return this==SUN?"SUN":"MON";

}

}

/*

//通过匿名内部类的方式分别实现nextDay()方法。当方法抽象时类必须抽象。

public abstract class WeekDay1 {

private WeekDay1(){}

public final static WeekDay1 SUN = new WeekDay1(){

public WeekDay1 nextDay(){

return MON;

}

};

public final static WeekDay1 MON = new WeekDay1(){

public WeekDay1 nextDay(){

return SUN;

}

};

// 第二种获取下一个元素方法

public abstract WeekDay1 nextDay();

public String toString(){

return this==SUN?"SUN":"MON";

}

}

*/

---------------------------------

14 枚举的基本应用

[java] view
plaincopy

package cn.itcast.day1;



public class EnumTest {



/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

WeekDay wd = WeekDay.SUN;

System.out.println(wd.toString());

System.out.println(wd.name());

System.out.println(wd.ordinal());

System.out.println(WeekDay.valueOf("wed".toUpperCase()));

System.out.println("WeekDay.valueOf(\"MON\")::"+WeekDay.valueOf("MON"));

System.out.println("WeekDay.valueOf(\"MON\")::"+WeekDay.values());

WeekDay[] weekdays = WeekDay.values();

for(WeekDay weekday : weekdays){

System.out.println("返回weekday的元素"+weekday);

}

}

public enum WeekDay{



SUN(2),MON,TUE,WED,THI,FRI,SAT;

//元素列表必须位于所有东西之前。所以构造方法要定义在元素后面,构造方法必须私有。

private WeekDay(){System.out.println("first");}

private WeekDay(int day){System.out.println("second");}

}

}

---------------------------------------------------

枚举类就相当于一个类,其中也可以定义构造方法、成员变量、普通方法和抽象方法。

枚举元素必须位于枚举体重的最开始部分,枚举元素列表的后面有分号与其他成员分隔。把枚举中的成员方法或

变量等放在枚举元素的前面,编译器报告错误。

带构造方法的枚举

构造方法必须定义成私有的。

如果有多个构造方法,该如何选择哪个构造方法?

枚举元素MON和MON()的效果一样,都是调用默认的构造方法。

带方法的枚举

定义枚举TrafficLamp

实现普通的next方法

实现抽象的next方法:每个元素分别是由枚举类的子类来生成的实例对象,这些子类采用类似内部类的方式进行定义。

增加上表示时间的构造方法。

枚举只有一个成员时,就可以作为一种单例的实现方式。

[java] view
plaincopy

package cn.itcast.day1;

public class EnumTest {



/**

* @param args

*/

public static void main(String[] args) {

TrafficLamp tl = TrafficLamp.RED;

System.out.println(tl);

System.out.println(TrafficLamp.RED.nexLamp().toString());



}

public enum TrafficLamp{

//这里每个RED,GREEN和YELLOW都是实例对象,为了使用抽象方法,必须用RED去复写抽象方法。相当于子类覆盖。

RED(50){

public TrafficLamp nexLamp(){

return GREEN;

};

},

GREEN(40){

public TrafficLamp nexLamp(){

return YELLOW;

}

},

YELLOW(10){

public TrafficLamp nexLamp(){

return RED;

}

};



public abstract TrafficLamp nexLamp();

//定义成员变量设定每个元素的时间。通过父类构造函数 Private TrafficLamp设定时间。

private int time;

private TrafficLamp(int time){this.time=time;}

}



}

[java] view
plaincopy

package cn.itcast.day1;

public class EnumTest {



/**

* @param args

*/

public static void main(String[] args) {

TrafficLamp tl = TrafficLamp.RED;

System.out.println(tl);

System.out.println(TrafficLamp.RED.nexLamp().toString());



}

public enum TrafficLamp{

//这里每个RED,GREEN和YELLOW都是实例对象,为了使用抽象方法,必须用RED去复写抽象方法。相当于子类覆盖。

RED(50){

public TrafficLamp nexLamp(){

return GREEN;

};

},

GREEN(40){

public TrafficLamp nexLamp(){

return YELLOW;

}

},

YELLOW(10){

public TrafficLamp nexLamp(){

return RED;

}

};



public abstract TrafficLamp nexLamp();

//定义成员变量设定每个元素的时间。通过父类构造函数 Private TrafficLamp设定时间。

private int time;

private TrafficLamp(int time){this.time=time;}

}



}

----------------------ASP.Net+Android+IOS开发.Net培训、期待与您交流!
----------------------详细请查看:http://edu.csdn.net
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: