package chape6;
/**
* 了解枚举
* 枚举是由一组固定的常量组成合法值的类型.
* @author leader
*
*/
public class Chape {
/**
* 显然,enum很像特殊的class,实际上enum声明定义的类型就是一个类。 而这些类都是类库中Enum类的子类 (java.lang.Enum<E>)。
* 它们继承了这个Enum中的许多有用的方法。 下面我们就详细介绍enum定义的枚举类的特征及其用法。 (后面均用Color举例)
* 1、Color枚举类是特殊的class,其枚举值(RED,BLUE...)是Color的类对象(类实例): Color c=Color.RED;
* 而且这些枚举值都是public static final的,也就是我们经常所定义的常量方式, 因此枚举类中的枚举值最好全部大写。
*
* @author leader
*
*/
/**
* 2、即然枚举类是class,当然在枚举类型中有构造器,方法和数据域。但是,枚举类的构造器有很大的不同: (1)
* 构造器只是在构造枚举值的时候被调用。 (2) 构造器只能私有private,绝对不允许有public构造器。
* 这样可以保证外部代码无法新构造枚举类的实例。这也是完全符合情理的, 因为我们知道枚举值是public static final的常量而已。
* 但枚举类的方法和数据域可以允许外部访问。
*/
enum Color {
RED(255, 0, 0), BLUE(1, 0, 255), BLACK(0, 0, 0), YELLOW(255, 255, 0), GREEN(0, 255, 0);
// 构造枚举值,比如RED(255,0,0) 私有构造函数 无法实例
private Color(int rv, int gv, int bv) {
this.redValue = rv;
this.greenValue = gv;
this.blueValue = bv;
}
public String toString() { // 自定义的public方法
return super.toString() + "(" + redValue + "," + greenValue + "," + blueValue + ")";
}
private int redValue; // 自定义数据域,private为了封装。
private int greenValue;
private int blueValue;
public int getRedValue() {
return redValue;
}
public void setRedValue(int redValue) {
this.redValue = redValue;
}
public int getGreenValue() {
return greenValue;
}
public void setGreenValue(int greenValue) {
this.greenValue = greenValue;
}
public int getBlueValue() {
return blueValue;
}
public void setBlueValue(int blueValue) {
this.blueValue = blueValue;
}
}
public static void main(String args[])
{
//Color colors=new Color(100,200,300); //wrong
/*Color color=Color.BLUE;
System.out.println(color); // 调用了toString()方法
*/
/**
* rdinal()方法: 返回枚举值在枚举类种的顺序。这个顺序根据枚举值声明的顺序而定
*/
System.out.println(Color.BLACK.ordinal());
System.out.println("1*****************************");
/**
* compareTo()方法: Enum实现了java.lang.Comparable接口,
* 因此可以比较象与指定对象的顺序。
* Enum中的compareTo返回的是两个枚举值的顺序之差。
* 当然,前提是两个枚举值必须属于同一个枚举类,否则会抛出ClassCastException()异常
*/
System.out.println(Color.BLACK.compareTo(Color.RED));
System.out.println("2*****************************");
/**
* values()方法: 静态方法,返回一个包含全部枚举值的数组。
*/
Color[] colors=Color.values();
for(Color c:colors){
System.out.println(c+",");
}
System.out.println("3*****************************");
/**
* toString()方法: 返回枚举常量的名称
*/
Color c=Color.RED;
System.out.println(c.toString());
System.out.println("4*****************************");
/**
* valueOf()方法: 这个方法和toString方法是相对应的,返回带指定名称的指定枚举类型的枚举常量。
*/
System.out.println(Color.valueOf("BLUE"));
System.out.println("5*****************************");
/**
* equals()方法: 比较两个枚举类对象的引用。
* JDK源代码:
* public final boolean equals(Object other) {
* return this==other;
* }
*/
Color r = Color.RED;
Color b = Color.RED;
System.out.println(r.equals(b));
System.out.println("6*****************************");
/**
* 枚举类可以在switch语句中使用
*/
Color color=Color.RED;
switch(color){
case RED: System.out.println("it's red");break;
case BLUE: System.out.println("it's blue");break;
case BLACK: System.out.println("it's blue");break;
}
System.out.println("7*****************************");
/**
* 讲私有的构造函数的参数进行封装 使用了set和get方法 就可以
* 获取每个成员的括号理的只了
*/
Color cv = Color.RED;
System.out.println(cv.getGreenValue());
cv.setGreenValue(898989);
System.out.println(cv.getGreenValue());
}
}
分享到:
相关推荐
effective java 读书笔记,第二版自己摘要并翻译,以备速查。
Effective Java读书笔记.pdf
2021年EFFECTIVEJAVA读书笔记.docx
effectiveJava的笔记
《Effective Java》第三版中文版目录 第一章 介绍 1 第二章 创建和销毁对象 4 1 考虑用静态工厂方法替换构造器 4 2 当遇到多个构造器参
Effective-Java读书笔记,别人分享的
《Effective Java》读书分享.pptx
Effective Java读书笔记,记载了大部分我觉的有用的东西,前半部分有代码说明,但后半部分的代码,太过琐碎,就没有整理
effective c++读书笔记和总结 effective c++读书笔记和总结
【Effective Java】阅读笔记markdown 文件
effective-java.pdf
Effective java 3 学习记录
Finix的精版Effective STL读书笔记
基于Effective Java第二版的读书笔记,可以帮助你更好的阅读这边Java圣经,更快的理解其思想
Effective Java Effective Java Effective Java
15. 使类和成员的可访问性最小化 16. 在公有类中使用访问方法而非公有域 17.使可变性最小化:不可变类
effective C++读书笔记,effective C++读书笔记,effective C++读书笔记
effective-java 配套代码