元注解是负责对其它注解进行说明的注解,自定义注解时可以使用元注解。Java 5 定义了 4 个注解,分别是 @Documented、@Target、@Retention 和 @Inherited。Java 8 又增加了 @Repeatable 和 @Native 两个注解。这些注解都可以在 java.lang.annotation 包中找到。下面主要介绍每个元注解的作用及使用。

本节示例会用到自定义注解,不了解可先阅读学习《Java自定义注解》一节。

@Documented

@Documented 是一个标记注解,没有成员变量。用 @Documented 注解修饰的注解类会被 JavaDoc 工具提取成文档。默认情况下,JavaDoc 是不包括注解的,但如果声明注解时指定了 @Documented,就会被 JavaDoc 之类的工具处理,所以注解类型信息就会被包括在生成的帮助文档中。

下面通过示例来了解它的用法,代码如下所示。

例 1

@Documented

@Target({ ElementType.TYPE, ElementType.METHOD })

public @interface MyDocumented {

public String value() default "这是@Documented注解";

}

测试类:

@MyDocumented

public class DocumentedTest {

/**

* 测试document

*/

@MyDocumented

public String Test() {

return "C语言中文网Java教程";

}

}

打开 Java 文件所在的目录,分别输入如下两条命令行:

javac MyDocumented.java DocumentedTest.java

javadoc -d doc MyDocumented.java DocumentedTest.java

运行成功后,打开生成的帮助文档,可以看到在类和方法上都保留了 MyDocument 的注解信息。如下图所示:

@Target

@Target 注解用来指定一个注解的使用范围,即被 @Target 修饰的注解可以用在什么地方。@Target 注解有一个成员变量(value)用来设置适用目标,value 是 java.lang.annotation.ElementType 枚举类型的数组,下表为 ElementType 常用的枚举常量。

名称

说明

CONSTRUCTOR

用于构造方法

FIELD

用于成员变量(包括枚举常量)

LOCAL_VARIABLE

用于局部变量

METHOD

用于方法

PACKAGE

用于包

PARAMETER

用于类型参数(JDK 1.8新增)

TYPE

用于类、接口(包括注解类型)或 enum 声明

例 2

自定义一个 MyTarget 注解,使用范围为方法,代码如下所示。

@Target({ ElementType.METHOD })

public @interface MyTarget {

}

class Test {

@MyTarget

String name;

}

如上代码第 6 行会编译错误,错误信息为:

The annotation @MyTarget is disallowed for this location

提示此位置不允许使用注解 @MyDocumented,@MyTarget 不能修饰成员变量,只能修饰方法。

@Retention

@Retention 用于描述注解的生命周期,也就是该注解被保留的时间长短。@Retention 注解中的成员变量(value)用来设置保留策略,value 是 java.lang.annotation.RetentionPolicy 枚举类型,RetentionPolicy 有 3 个枚举常量,如下所示。

SOURCE:在源文件中有效(即源文件保留)

CLASS:在 class 文件中有效(即 class 保留)

RUNTIME:在运行时有效(即运行时保留)

生命周期大小排序为 SOURCE < CLASS < RUNTIME,前者能使用的地方后者一定也能使用。如果需要在运行时去动态获取注解信息,那只能用 RUNTIME 注解;如果要在编译时进行一些预处理操作,比如生成一些辅助代码(如 ButterKnife),就用 CLASS 注解;如果只是做一些检查性的操作,比如 @Override 和 @SuppressWarnings,则可选用 SOURCE 注解。

@Inherited

@Inherited 是一个标记注解,用来指定该注解可以被继承。使用 @Inherited 注解的 Class 类,表示这个注解可以被用于该 Class 类的子类。就是说如果某个类使用了被 @Inherited 修饰的注解,则其子类将自动具有该注解。

例 3

创建一个自定义注解,代码如下所示:

@Target({ ElementType.TYPE })

@Inherited

@Retention(RetentionPolicy.RUNTIME)

public @interface MyInherited {

}

测试类代码如下:

@MyInherited

public class TestA {

public static void main(String[] args) {

System.out.println(TestA.class.getAnnotation(MyInherited.class));

System.out.println(TestB.class.getAnnotation(MyInherited.class));

System.out.println(TestC.class.getAnnotation(MyInherited.class));

}

}

class TestB extends TestA {

}

class TestC extends TestB {

}

运行结果为:

@MyInherited()

@MyInherited()

@MyInherited()

@Repeatable

@Repeatable 注解是 Java 8 新增加的,它允许在相同的程序元素中重复注解,在需要对同一种注解多次使用时,往往需要借助 @Repeatable 注解。Java 8 版本以前,同一个程序元素前最多只能有一个相同类型的注解,如果需要在同一个元素前使用多个相同类型的注解,则必须使用注解“容器”。

例 4

Java 8 之前的做法:

public @interface Roles {

Role[] roles();

}

public @interface Roles {

Role[] value();

}

public class RoleTest {

@Roles(roles = {@Role(roleName = "role1"), @Role(roleName = "role2")})

public String doString(){

return "这是C语言中国网Java教程";

}

}

Java 8 之后增加了重复注解,使用方式如下:

public @interface Roles {

Role[] value();

}

@Repeatable(Roles.class)

public @interface Role {

String roleName();

}

public class RoleTest {

@Role(roleName = "role1")

@Role(roleName = "role2")

public String doString(){

return "这是C语言中文网Java教程";

}

}

不同的地方是,创建重复注解 Role 时加上了 @Repeatable 注解,指向存储注解 Roles,这样在使用时就可以直接重复使用 Role 注解。从上面例子看出,使用 @Repeatable 注解更符合常规思维,可读性强一点。

两种方法获得的效果相同。重复注解只是一种简化写法,这种简化写法是一种假象,多个重复注解其实会被作为“容器”注解的 value 成员的数组元素处理。

@Native

使用 @Native 注解修饰成员变量,则表示这个变量可以被本地代码引用,常常被代码生成工具使用。对于 @Native 注解不常使用,了解即可。

c JAVA 注解,Java元注解作用及使用相关推荐

  1. 玩转Java注解:元注解、内置注解、自定义注解的原理和实现

    点击关注公众号,实用技术文章及时了解 来源:www.jianshu.com/p/ddd0b880641a 前言 Java 注解(Annotation)又称 Java 标注,是 JDK5.0 引入的一种 ...

  2. java path 注解_Java内置系统注解和元注解

    第一节:注解(Annotation)的作用 Annotation(注解)是JDK5.0及以后版本引入的.它的作用是修饰程序元素.什么是程序元素呢?例如:包.类.构造方法.方法.成员变量等. 注解,就是 ...

  3. java 四种元注解@Target、@Retention、@Documented 和@Inherited

    java 四种元注解@Target.@Retention.@Documented 和@Inherited @Target 表示该注解用于什么地方,可能的值在枚举类 ElemenetType 中,包括: ...

  4. 注解_自定义注解_元注解

    * 元注解:用于描述注解的注解 * @Target:描述注解能够作用的位置* ElementType取值:* TYPE:可以作用于类上* METHOD:可以作用于方法上* FIELD:可以作用于成员变 ...

  5. 注解整理 - 元注解,lombok注解,spring 注解,springboot注解,springmvc注解

    注解大全 java四种元注解 @Target @Retention @Documented @Inherited lombok注解 lombok注解为什么强大 lombok注解的使用方式 1.安装lo ...

  6. 注解(7)_元注解_元注解的概念_@Retention_@Target_@Documented_@Inherited

    元注解的概念 元注解是用于修饰其他注解的注解. (1)元注解本身也是注解. (2)元注解是用来修饰别的注解的. JDK5.0提供了四种元注解: @Retention @Target @Document ...

  7. Spring组合注解与元注解

    为什么80%的码农都做不了架构师?>>>    1. 可以注解到别的注解上的注解称为元注解,被注解的注解称为组合注解,通过组合注解可以很好的简化好多重复性的注解操作 2. 示例组合注 ...

  8. Spring组合注解和元注解

    2019独角兽企业重金招聘Python工程师标准>>> 元注解:可以注解到其他注解的注解. 组合注解:被注解的注解,组合注解具备元注解的功能. @Configuration就是一个组 ...

  9. java的标准注解和元注解

    目录 注解Annotation实现原理与自定义注解例子 1.什么是注解 2.注解的用处 3.注解的原理 4.元注解 5.常见标准的Annotation 6.自定义注解 7.自定义注解实例 注解Anno ...

  10. Java获取元注解_Java 元注解

    一.介绍 元注解的作用就是负责注解其他注解,Java5.0定义了4个标准的meta-annotation类型,它们被用来提供对其它 annotation类型作说明.Java5.0定义的元注解: @Ta ...

最新文章

  1. 由于未能创建 Microsoft Visual C# 2008 编译器,因此未能打开项目 ...的解决方法...
  2. ABP理论学习之工作单元(Unit of Work)
  3. IIS6.0 日期格式问题
  4. 国产岚图入局高端智能电动车,对标特斯拉,放话一年内量产
  5. UIView上的控件使用push方法跳转
  6. python sql语句传参数_pyMySQL SQL语句传参问题,单个参数或多个参数说明
  7. Linux 播放网易云音乐(树莓派)
  8. 2020中国十大最丑建筑出炉,你觉得哪个更丑?
  9. AT2368-[AGC013B]Hamiltonish Path【构造】
  10. Android ANR视角InputDispatcher
  11. 通信系统概论_现代通信系统概论 第一章 概述(1)
  12. 2.1 maven配置多镜像地址
  13. 计算机辅助制造讲义翻译,计算机辅助制造讲义-2007-2演示文稿.PPT
  14. 深入理解计算机系统——地址翻译
  15. 什么是嵌入式?你眼中的嵌入式是怎么样的?怎么学嵌入式?教你五分钟看懂嵌入式。
  16. 个人邮箱Outlook登录入口在哪,遇到登录邮箱服务器配置错误的解决办法
  17. (附源码)SSM学生社团管理系统JAVA计算机毕业设计项目
  18. js之splice 和 slice
  19. 银行春招:六大行薪资待遇知多少?(上)
  20. 砖家:“IPV9” - 美国没有成功,中国搞成了

热门文章

  1. 我为什么觉得数据产品经理更吃香了?
  2. python代码自动格式化_代码的自动格式化
  3. mysql %和正则_mysql 正则模式和like模糊查询
  4. 积跬步以至千里_《荀子》名句76则:不积跬步,无以至千里;不积小流,无以成江海...
  5. 【自动化测试爬虫系列】Selenium Webdriver 介绍
  6. kubernetes实战篇之创建密钥自动拉取私服镜像
  7. java web 页面提速
  8. MeayunDB学习笔记(一) MeayunDB介绍及安装
  9. Android——GridLayout
  10. 怎么用vnc访问自己电脑,并且同时又是同一个会话?