1、枚举类的理解:类的对象只有有限个、确定的。我们称此类为枚举类
2、当需要定义一组常量时,强烈建议使用枚举类
3、如果枚举类中只有一个对象,则可以作为单例模式的实现方式
//自定义枚举类
class Season{
//1.声明Season对象的属性:private final修饰
private final String seasonName;
private final String seasonDesc;
//2.私有化类的构造器,并给对象属性赋值
private Season(String seasonName, String seasonDesc) {
this.seasonName = seasonName;
this.seasonDesc = seasonDesc;
}
//3.提供当前枚举类的多个对象:public static final的
public static final Season SPRING = new Season("春天", "春暖花开");
public static final Season SUMMER = new Season("夏天", "烈日高照");
public static final Season AUTUMN = new Season("秋天", "秋高气爽");
public static final Season WINTER = new Season("冬天", "冰天雪地");
//4.其他诉求1:获取枚举类的属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
//4.其他诉求2:提供toString方法
@Override
public String toString() {
return "Season [seasonName=" + seasonName + ", seasonDesc=" + seasonDesc + "]";
}
}
//使用Enum枚举类
//使用Enum枚举类可以不重写toString,因为Season1的父类不是String,打印出来不是地址
enum Season1{
//1.提供当前枚举类对象,多个对象之间用","隔开,末尾对象用";"结束
SPRING("春天", "春暖花开"),
SUMMER("夏天", "烈日高照"),
AUTUMN("秋天", "秋高气爽"),
WINTER("冬天", "冰天雪地");
//2.声明Season对象的属性:private final修饰
private final String seasonName;
private final String seasonDesc;
//3.私有化类的构造器,并给对象属性赋值
private Season1(String seasonName, String seasonDesc) {
this.seasonName = seasonName;
this.seasonDesc = seasonDesc;
}
//4.其他诉求1:获取枚举类的属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
//4.其他诉求2:提供toString方法
// @Override
// public String toString() {
// return "Season1 [seasonName=" + seasonName + ", seasonDesc=" + seasonDesc + "]";
// }
}
Season1 spring = Season1.SPRING;
//toString
System.out.println(spring);//SPRING
System.out.println(Season1.class.getSuperclass());//class java.lang.Enum
//values()
Season1[] ss = Season1.values();
for (Season1 season1 : ss) {
System.out.println(season1);//SPRING SUMMER AUTUMN WINTER
}
//valueOf()
Season1 s1 = Season1.valueOf("SPRING");
System.out.println(s1);//SPRING
public class Test2 {
public static void main(String[] args) {
Season1 spring = Season1.SPRING;//SPRING
System.out.println(spring);
System.out.println(Season1.class.getSuperclass());//class java.lang.Enum
Season1[] ss = Season1.values();
for (Season1 season1 : ss) {
System.out.println(season1);//SPRING SUMMER AUTUMN WINTER
}
Season1 s1 = Season1.valueOf("SPRING");
System.out.println(s1);//SPRING
s1.show();
//使用接口覆盖抽象方法的两种结果
//这是一个季节
//这是春天
}
}
interface info{
void show();
}
//使用Enum枚举类
//使用Enum枚举类可以不重写toString,因为Season1的父类不是String,打印出来不是地址
enum Season1 implements info{
//1.提供当前枚举类对象,多个对象之间用","隔开,末尾对象用";"结束
SPRING("春天", "春暖花开"){
public void show() {
System.out.println("这是春天");
}
},
SUMMER("夏天", "烈日高照"){
public void show() {
System.out.println("这是夏天");
}
},
AUTUMN("秋天", "秋高气爽"){
public void show() {
System.out.println("这是秋天");
}
},
WINTER("冬天", "冰天雪地"){
public void show() {
System.out.println("这是冬天");
}
};
//2.声明Season对象的属性:private final修饰
private final String seasonName;
private final String seasonDesc;
//3.私有化类的构造器,并给对象属性赋值
private Season1(String seasonName, String seasonDesc) {
this.seasonName = seasonName;
this.seasonDesc = seasonDesc;
}
//4.其他诉求1:获取枚举类的属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
// @Override
// public void show() {
// System.out.println("这是一个季节");
//
// }
}
注解,也叫元数据,jdk5.0引入的,与类、接口、枚举在同一个层次
它可以声明在包、类、方法、字段、局部变量、方法参数等的前面
框架=注解+反射+设计模式
编写文档:生成文档相关的注释
编译检查:在编译时进行格式检查(JDK内置的三个基本注解)
代码分析:通过代码里标识的元数据对代码进行分析【使用反射】
参照@SuppressWarnings定义
内部定义成员,通常使用value表示
可以指定成员的默认值,使用default定义
如果自定义注解没有成员,表明是一个标识作用
public @Interface 注解名{属性列表/无属性}
如果注解体中无任何属性,其本质就是标记注解。但是与其标注注解还少了上边修饰的元注解。
如果注解有成员,在使用注解时,需要指明成员的值
自定义注解必须配上注释的信息处理流程(使用反射)才有意义
用于描述注解的注解。一般使用元注解来限制自定义注解的使用范围、生命周期等信息
public @interface Target{
ElementType[] value();
}
public enum ElementType{
TYPE;
FIELD;
METHOD;
PARAMETER;
……
}
@Retention:指定被修饰的注解的生命周期:SOURCE、CLASS(默认行为)、RUNTIME
@Documented:表示所修饰的注解在被javadoc解析时,保留下来
@Inherited:指定了被修饰的注解修饰程序元素的时候是可以被子类继承的