利用 Java 的反射机制,能够在运行时获取 Java 类的注解信息。html
注解是 Java 5 的一个新特性,是插入代码中的一种注释或者说是元数据。注解并非程序代码,能够对程序做出解释,相似于注释。可是注解能够被相关程序读取(例如编译器)。java
注解能够用在两个时刻:web
注解的格式:注解以 @
开头,后面跟注释名,还能够加参数。数组
注解使用的地方:package,class,method,field 上均可以使用注解。ide
@MyAnnotation(name="someName", value = "Hello World") public class TheClass { }
@Override public String toString() { // 这里若是方法名写错,会报错 return ""; }
注解的定义与接口的定义类似,可是须要在 interface 关键字前加 @
符号:svg
@Documented @Retention(RetentionPolicy.RUNTIME) @Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE}) public @interface Deprecated { }
元注解负责注解其余注解。Java 定义了4个标准的元注解类型,用来对其它 注解类型做说明:工具
@Target
用于描述注解的使用位置。例如 @Target(ElementType.TYPE)
表示这个注解只能用在类型上面(好比类跟接口)。参数能够同时指定多个值,例如@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})
。ElementType 的可用值有:spa
@Retention
用于描述注解的生命周期。可取值有:code
@Documented
用于描述是否能够被 javadoc 之类的工具文档化。@Documented
是标记注解,没有成员。xml
@Inherited
用于描述某个被标注的类型是被继承的。若是一个使用了 @Inherited
修饰的annotation类型被用于一个class,则这个注解将被用于该class的子类。
当@Inherited 类型标注的注解的Retention是RetentionPolicy.RUNTIME,则反射API加强了这种继承性。若是咱们使用 java.lang.reflect 反射机制去查询一个@Inherited 类型的注解时,反射代码检查将展开工做:检查class和其父类,直到发现指定的annotation类型被发现,或者到达类继承结构的顶层。
定义在 java.lang.Override
中,此注解只能用于修饰方法,表示重写父类中的方法。
定义在 java.lang.Deprecated
中,能够用于修饰方法、属性或类,表示方法、属性或类已经废弃,不建议使用。
定义在 java.lang.SuppressWarnings
中,抑制编译时的警告信息。能够指定如下的一个或多个参数,例如 `@SuppressWarngins(value={“unchecked”, “path”}):
使用 @interface
自定义注解时,自动继承 java.lang.annotation.Annotation
接口。注解不能继承其余的注解或接口。
@interface
用来声明一个注解,其中的每个方法其实是声明了一个配置参数。方法的名称就是参数的名称,返回值类型就是参数的类型(返回值类型只能是基本数据类型(int,float,boolean,byte,double,char,long,short)、Class、String、enum 及这些类型对应的数组)。能够经过default来声明参数的默认值。
定义注解的语法:
public @interface 注解名 {定义体}
@MyAnnotation(name="someName", value = "Hello World") public class TheClass { }
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface MyAnnotation { public String name(); public String value(); }
只要是 Runtime 级别的注解,无论是类、方法、参数、变量注解均可以在运行时经过反射机制加载类后,进行访问,具体方法能够参考 这里。
Class aClass = TheClass.class; Annotation annotation = aClass.getAnnotation(MyAnnotation.class); if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("name: " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); }