首页 > 编程 > Java > 正文

JDK 5 提供的注解:Target、Inherited和Documented的区别

2019-11-26 14:31:47
字体:
来源:转载
供稿:网友

JDK 5提供的注解,除了Retention以外,还有另外三个,即Target 、Inherited 和 Documented。

Target 目标即Target注解用在哪里, 定义了注解使用的时机,即注解所适用的程序元素的种类。如果注解类型声明中不存在 Target 元注解,则声明的类型可以用在任一程序元素上。如果存在这样的元注解,则编译器强制实施指定的使用限制。

Target 定义如下:

@Documented@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.ANNOTATION_TYPE)public @interface Target {  ElementType[] value();}

可以看到,Target 只有一个value属性,类型为枚举类型ElementType。ElementType 声明如下:

public enum ElementType {  /** 注解可以用在类、接口(包括注解类型)或枚举声明 */  TYPE,  /** 字段声明(包括枚举常量) */  FIELD,  /** 方法声明 */  METHOD,  /** 参数声明 */  PARAMETER,  /** 构造方法声明 */  CONSTRUCTOR,  /** 局部变量声明 */  LOCAL_VARIABLE,  /** 注解类型声明 */  ANNOTATION_TYPE,  /** 包声明 */  PACKAGE}

Documented注解表明制作javadoc时,是否将注解信息加入文档。如果注解在声明时使用了@Documented,则在制作javadoc时注解信息会加入javadoc。注解声明如下:

@Documented@Retention(value=RUNTIME)@Target(value=ANNOTATION_TYPE)//说明该注解只能在声明注解时使用,即元注解public @interface Documented {}

Inherited 注解同样是元注解,声明如下:

@Documented@Retention(value=RUNTIME)@Target(value=ANNOTATION_TYPE)public @interface Inherited {}

Inherited 注解表明注解是否会被子类继承,缺省情况是不继承的。当注解在声明时,使用了@Inherited注解,则该注解会被使用了该注解的类的子类所继承。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表