@Retention 仅被用于描述注解的生命周期
下面是Retention注解的定义
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Retention {
/**
* Returns the retention policy.
* @return the retention policy
*/
RetentionPolicy value();
}
在它的定义代码中,仅仅存在一个属性 RetentionPolicy
其中 RetentionPolicy 包含三种值,分别为 1:SOURCE、2:CLASS、3:RUNTIME
public enum RetentionPolicy {
/**
* 注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;
*/
SOURCE,
/**
* 注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期;
*/
CLASS,
/**
* 注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在;
* 如果要用反射的话,这是必须项
*/
RUNTIME
}
三者的生命周期长度 SOURCE < CLASS < RUNTIME ,所以前者能作用的地方后者一定也能作用。一般如果需要在运行时去反射获取注解信息,那只能用 RUNTIME 注解;