Home Java Annotation
Post
Cancel

Java Annotation

Java 注解(Annotation)又称 Java 标注,是 JDK5.0 引入的一种注释机制。

Java 语言中的类、方法、变量、参数和包等都可以被标注。和 Javadoc 不同,Java 标注可以通过反射获取标注内容。在编译器生成类文件时,标注可以被嵌入到字节码中。Java 虚拟机可以保留标注内容,在运行时可以获取到标注内容 。 当然它也支持自定义 Java 标注。

Java 定义了一套注解,共有 7 个,3 个在 java.lang 中,剩下 4 个在 java.lang.annotation 中。Java 7 又增加了3个注解。

作用在代码的注解

  • @Override - 检查该方法是否是重写方法。如果发现其父类,或者是引用的接口中并没有该方法时,会报编译错误。
  • @Deprecated - 标记过时方法。如果使用该方法,会报编译警告。
  • @SuppressWarnings - 指示编译器去忽略注解中声明的警告。

元注解

  • @Retention - 标识这个注解怎么保存,是只在代码中,还是编入class文件中,或者是在运行时可以通过反射访问。
  • @Documented - 标记这些注解是否包含在用户文档中。
  • @Target - 标记这个注解应该是哪种 Java 成员。
  • @Inherited - 标记这个注解是继承于哪个注解类(默认注解并没有继承于任何子类)

Java 7 新增

  • @SafeVarargs - Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
  • @FunctionalInterface - Java 8 开始支持,标识一个匿名函数或函数式接口。
  • @Repeatable - Java 8 开始支持,标识某注解可以在同一个声明上使用多次。

img

三个重要类:Annotation、ElementType、RetentionPolicy

Annotation,是个接口,声明了 equalshashcodetoStringannotationType 方法。

ElementType,是个枚举类型,指定注解类型,表示其可以使用的地方。

1
2
3
4
5
6
7
8
9
10
11
12
public enum ElementType {
    TYPE,               /* 类、接口(包括注释类型)或枚举声明  */
    FIELD,              /* 字段声明(包括枚举常量)  */
    METHOD,             /* 方法声明  */
    PARAMETER,          /* 参数声明  */
    CONSTRUCTOR,        /* 构造方法声明  */
    LOCAL_VARIABLE,     /* 局部变量声明  */
    ANNOTATION_TYPE,    /* 注释类型声明  */
    PACKAGE             /* 包声明  */
    TYPE_PARAMETER,		/* 类型参数 */
    TYPE_USE			/* 类型使用 */
}

RetentionPolicy,也是枚举,表示如何保存该注解。

1
2
3
4
5
public enum RetentionPolicy {
    SOURCE,		/* 注解将被编译器丢弃(注解信息只会保留在源码里,源码经过编译后,注解信息会被丢弃,不会保留在编译好的class文件里),如 @Override */
    CLASS,		/* 默认级别,注解在class文件中可用,但会被VM丢弃(该类型的注解信息会保留在源码里和class文件里,在执行的时候不会加载到虚拟机JVM) */
    RUNTIME		/* VM将在运行期也保留注解信息,因此可以通过反射机制读取注解的信息(源码、class文件和执行的时候都有注解的信息) */
}

元注解

1
2
3
4
@Documented  -- @Documented 所标注内容可以出现在javadoc中
@Inherited   -- @Inherited只能被用来标注Annotation类型”,它所标注的Annotation具有继承性
@Retention   -- @Retention只能被用来标注Annotation类型”,而且它被用来指定Annotation的RetentionPolicy属性默认 class 级别
@Target      -- @Target只能被用来标注Annotation类型”,而且它被用来指定Annotation的ElementType属性没有 Target 的注解默认可以用在所有地方

@SuppressWarnings 常用关键字

1
2
3
4
5
6
7
deprecation  -- 使用了不赞成使用的类或方法时的警告
unchecked    -- 执行了未检查的转换时的警告例如当使用集合时没有用泛型 (Generics) 来指定集合保存的类型
fallthrough  --  Switch 程序块直接通往下一种情况而没有 Break 时的警告
path         -- 在类路径源文件路径等中有不存在的路径时的警告
serial       -- 当在可序列化的类上缺少 serialVersionUID 定义时的警告
finally      -- 任何 finally 子句不能正常完成时的警告
all          -- 关于以上所有情况的警告
This post is licensed under CC BY 4.0 by the author.