第八章:枚举类与注解
第八章:枚举类与注解
8.1:枚举类的使用
类的对象只有有限个,确定的。我们称此类为枚举类。当需要定义一组常量是,强烈建议使用枚举类。如果枚举类中只有一个对象,则可以作为单例模式的实现方式。
-
如何定义枚举类
-
方式一:
JDK5.0
之前,自定义枚举类。public class SeasonTest {public static void main(String[] args) {Season spring = Season.SPRING;System.out.println(spring); // Season{seasonName=春天,seasonDesc=春暖花开}} } //自定义枚举类 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.其他诉求1:提供toString()@Overridepublic String toString() {return "Season{" +"seasonName='" + seasonName + '\'' +", seasonDesc='" + seasonDesc + '\'' +'}';} }
-
方式二:
JDK5.0
,可以使用enum
关键字定义枚举类。public class SeasonTest1 {public static void main(String[] args) {Season1 summer = Season1.SUMMER;System.out.println(summer); // Season{seasonName=春天,seasonDesc=春暖花开}System.out.println(Season1.class.getSuperclass()); // Enum} } //使用enum关键字枚举类 enum Season1 implements Info{//1.提供当前枚举类的对象,多个对象之间用","隔开,末尾对象";"结束SPRING("春天","春暖花开"),SUMMER("夏天","夏日炎炎"),AUTUMN("秋天","秋高气爽"),WINTER("冬天","冰天雪地");//2.声明Season对象的属性:private final修饰private final String seasonName;private final String seasonDesc;//2.私有化类的构造器,并给对象属性赋值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.其他诉求1:提供toString()@Overridepublic String toString() {return "Season1{" +"seasonName='" + seasonName + '\'' +", seasonDesc='" + seasonDesc + '\'' +'}';} }
-
-
Enum
类中常用的方法values()
:返回枚举类型的对象数组。该方法可以很方便地遍历所有的枚举值。valueOf(String str)
:返回枚举类中对象名str
的对象,如果没有就抛异常。toString()
:返回当前枚举类对象常量名称。
Season1 summer = Season1.SUMMER; //toString():返回枚举类对象的名称 System.out.println(summer.toString()); //values():返回所有的枚举类对象构成的数组 Season1[] values = Season1.values(); for(int i = 0;i < values.length;i++){System.out.println(values[i]); } //valueOf(String objName):返回枚举类中对象名是objName的对象。 Season1 winter = Season1.valueOf("WINTER"); System.out.println(winter);
-
使用
enum
关键字定义的枚举类实现接口的情况- 情况一:实现接口,在
enum
类中实现抽象方法。 - 情况二:让枚举类的对象分别实现接口中的抽象方法。
- 情况一:实现接口,在
8.2:注解
-
理解注解(
Annotation
)- 从
JDK 5.0
开始,Java
增加了对元数据MetaData
的支持,也就是Annotation
(注解)。 Annotation
其实就是代码里的特殊标记,这些标记可以在编译,类加载,运行时被读取,并执行相应的处理。通过使用Annotation
,程序员可以在不改变原有逻辑的情况下,在源文件中嵌入一些补充信息。
- 从
-
注解实例
-
@Override
:限定重写父类方法,该注解只能用于方法。class Person{private String name;private int age;public Person() {}public Person(String name, int age) {this.name = name;this.age = age;}public void walk() {System.out.println("人走路");} }class Student extends Person{@Overridepublic void walk() {System.out.println("学生走路");} }
-
@Deprecated
:用于表示所修饰的元素(类,方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择。@Deprecated public Date(int year, int month, int date) {this(year, month, date, 0, 0, 0); }
-
@SuppressWarnings
:抑制编译器警告。@SuppressWarnings("unused") int num = 10; @SuppressWarnings({"unused", "rawtypes"}) ArrayList list = new ArrayList();
-
-
自定义
Annotation
- 注解类型声明为:
@interface
。 - 自定义注解自动继承了
java.lang.annotation.Annotation
接口。 - 注解的成员变量在
Annotation
定义中以无参数方法的形式来声明。其方法名和返回值定义了该成员的名字和类型。我们称为配置参数。类型只能是八种基本数据类型、String
、Class
、enum
、Annotation
类型。 - 内部定义成员,通常使用
value
表示。 - 可以指定成员的默认值,使用
default
定义。 - 如果定义的注解含有配置参数,那么使用时必须指定参数值,除非它有默认值。格式是
参数名 = 参数值
,如果只有一个参数成员,且名称为value
,可以省略value=
。 - 如果自定义注解没有成员,表名是一个标识作用。
public @interface MyAnnotation {String value() default "hello"; }
注意:自定义注解必须配上注解的信息处理流程才有意义。
- 注解类型声明为:
-
JDK
中的元注解-
JDK
的元Annoation
用于修饰其他Annotation
定义。 -
JDK 5.0
提供了4个标准的meta-annontation
类型,分别是:-
Retention
只能用于修饰一个
Annotation
定义,用于指定该Annotation
的生命周期,@Rentention
包含一个RetentionPolicy
类型的成员变量,使用@Rentention
时必须为该value
成员变量指定值:RetentionPolicy.COURCE
:在源文件中有效(即源文件保留),编译器直接丢弃这种策略的注释。RetentionPolicy.CLASS
:在class
文件中有效(即class
保留),当运行Java
程序时,不会保留注解。这是默认值。RetentionPolicy.RUNTIME
:在运行时有效(即运行时保留),当运行Java
程序时,JVM
会保留注释。程序可以通过反射获取该注释。
-
Target
用于修饰
Annotation
定义,用于指定被修饰的Annotation
能用于修饰哪些程序元素。@Target
也包含一个名为value
的成员变量。
-
Documented
用于指定被该元
Annotation
修饰的Annotation
类将被javadoc
工具提取成文档。默认情况下,javadoc
是不包括注解的。 定义为
Documented
的注解必须设置Retention
值为RUNTIME
。 -
Inherited
被它修饰的
Annotation
将具有继承性。如果某个类使用了被@Inherited
修饰的Annotation
,则其子类将自动具有该注解。
-
-
-
JDK 8
中注解的新特性-
可重复注解
- 在
MyAnnotation
上声明@Repeatable
,成员值为MyAnnotations.class
MyAnnotation
的Target
和Retention
等元注解与MyAnnotations
相同
@Inherited @Repeatable(MyAnnotations.class) @Retention(RetentionPolicy.RUNTIME) @Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE,TYPE_PARAMETER,TYPE_USE}) public @interface MyAnnotation {String value() default "hello"; }
@Inherited @Retention(RetentionPolicy.RUNTIME) @Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE,TYPE_PARAMETER,TYPE_USE}) public @interface MyAnnotations {MyAnnotation[] value(); }
@MyAnnotation(value = "hi") @MyAnnotation(value = "abc") class Person{ }
- 在
-
类型注解
ElementType.TYPE_RARAMETER
:表示该注解能写在类型变量的声明语句中。ElementType.TYPE_USE
:表示该注解能写在使用类型的任何语句中。
-