注解
注释不会编译到文件中,注解可以编译到文件中。
注解的作用:
- 编译格式检查。
- 反射中解析。
- 生成帮助文档。
- 跟踪依赖类。
- 方法、变量、参数、包都可以添加注解。
内置注解:
- @Override重写
- @Deprecater 废弃
- @SafeVarargs 忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
- @FunctionalInterface: 函数式接口。Java 8 开始支持,标识一个匿名函数或函数式接口。
- @Repeatable:标识某注解可以在同一个声明上使用多次。Java 8 开始支持,标识某注解可以在同一个声明上使用多次。
- SuppressWarnings:抑制编译时的警告信息。定义在java.lang.SuppressWarnings
三种使用方式
1. @SuppressWarnings("unchecked") [^ 抑制单类型的警告]
2. @SuppressWarnings("unchecked","rawtypes") [^ 抑制多类型的警告]
3. @SuppressWarnings("all") [^ 抑制所有类型的警告]
四大元注解:
- @Retention - 标识这个注解怎么保存,是只在代码中,还是编入class文件中,或者是在运行时可以通过反射访问。
- @Documented - 标记这些注解是否包含在用户文档中 javadoc。
- @Target - 标记这个注解应该是哪种 Java 成员。
- @Inherited - 标记这个注解是自动继承的:
@Inherited:
1. 子类会继承父类使用的注解中被@Inherited修饰的注解。
2. 接口继承关系中,子接口不会继承父接口中的任何注解,不管父接口中使用的注解有没有被@Inherited修饰。
3. 类实现接口时不会继承任何接口中定义的注解。
2.5、自定义注解
2.5.1、注解架构
(01) Annotation与RetentionPolicy 与ElementType 。每 1 个 Annotation 对象,都会有唯一的 RetentionPolicy 属性;至于 ElementType 属性,则有 1~n个。
(02) ElementType(注解的用途类型)。"每 1 个 Annotation" 都与 "1~n 个 ElementType" 关联。当 Annotation 与某个 ElementType 关联时,就意味着:Annotation有了某种用途。例如,若一个 Annotation 对象是 METHOD 类型,则该Annotation 只能用来修饰方法。
package java.lang.annotation;
public enum ElementType {
TYPE, /* 类、接口(包括注释类型)或枚举声明 */
FIELD, /* 字段声明(包括枚举常量) */
METHOD, /* 方法声明 */
PARAMETER, /* 参数声明 */
CONSTRUCTOR, /* 构造方法声明 */
LOCAL_VARIABLE, /* 局部变量声明 */
ANNOTATION_TYPE, /* 注释类型声明 */
PACKAGE /* 包声明 */
}
(03) RetentionPolicy(注解作用域策略)。
"每 1 个 Annotation" 都与 "1 个 RetentionPolicy" 关联。
a) 若 Annotation 的类型为 SOURCE,则意味着:Annotation 仅存在于编译器处理期间,编译器处理完之后,该 Annotation 就没用了。 例如," @Override" 标志就是一个 Annotation。当它修饰一个方法的时候,就意味着该方法覆盖父类的方法;并且在编译期间会进行语法检查!编译器处理完后,"@Override" 就没有任何作用了。
b) 若 Annotation 的类型为 CLASS,则意味着:编译器将 Annotation 存储于类对应的 .class 文件中,它是 Annotation 的默认行为。
c) 若 Annotation 的类型为 RUNTIME,则意味着:编译器将 Annotation 存储于 class 文件中,并且可由JVM读入。
package java.lang.annotation;
public enum RetentionPolicy {
SOURCE, /* Annotation信息仅存在于编译器处理期间,编译器处理完之后就没有该
Annotation信息了 */
CLASS, /* 编译器将Annotation存储于类对应的.class文件中。默认行为 */
RUNTIME /* 编译器将Annotation存储于class文件中,并且可由JVM读入 */
}
自定义注解
1. 定义的注解,自动继承了java.lang,annotation.Annotation接口。
2. 注解中的每一个方法,实际是声明的注解配置参数。
方法的名称就是配置参数的名称。
方法的返回值类型,就是配置参数的类型。只能是:基本类型/Class/String/enum。
3. 可以通过default来声明参数的默认值。
4. 如果只有一个参数成员,一般参数名为value。
5. 注解元素必须要有值,我们定义注解元素时,经常使用空字符串、0作为默认值。