注解
作用
编写文档:通过代码里标识的元数据生成文档【生成文档doc文档】 javadoc代码分析:通过代码里标识的元数据对代码进行分析【使用反射】
编译检查:通过代码里标识的元数据让编译器能够实现基本的编译检查【Override】
JDK预定义的注解
- @Override:检测被该注解标注的方法是否继承自父类(接口)
- @Oeprecated:将该注解标注的内容,已过时
- @SuppressWarnings:压制警告
1 | //压制警告,关于AnnoDemo的所有代码警告都不显示 |
自定义注解
格式
元注解 public @interface 注解名称{ 属性列表 }
1 | public MyAnno { |
- 注解的本质上就是一个接口,默认继承
java.lang.annotation.Annotation
1 | E:\JAVA\javase\study1\src\hxx\Annotation>javac MyAnno.java |
属性:接口中的抽象方法
属性的返回值类型:
- 基本数据类型
- String
- 枚举
- 注解
- 以上类型的数组
定义了属性,在使用时需要给属性赋值
- 如果定义了属性时,使用default关键字给属性默认初始化值,则使用注解时,可以不进行属性的赋值
- 如果只有一个属性需要赋值,并且属性的名称是value,则value可以省略,直接定义值即可
- 数组赋值时,使用{}包裹。如果数组中只有一个值,则{}可以省略
1 | public MyAnno { |
元注解:描述注解的注解
@Target :描述注解能够作用的位置
- ElementType取值:
- TYPE:可以作用于类上
- METHOD:可以作用于方法上
- FIELD:可以作用域成员变量上
- ……..
@Retention:描述注解被保留的阶段
- RetentionPolicy取值
- RUNTIME:运行时(一般自定义的注解使用),当前被描述的注解,会保留到class字节码文件中,并被JVM读取到
- SOURCE:
- CLASS:
@Document:描述注解是否被抽取到api文档中
@Inherited:描述注解是否被子类注解
- ElementType取值:
解析注解
- 获取注解中定义的属性值
案例1:不修改代码,执行指定类的指定方法
- 在注解中进行配置
1 | //可用于类 |
- 在测试中解析注解
1 |
|
案例2:利用注解对类方法进行测试
- 定义计算器类
1 | public class Calculator { |
- 定义注解
1 |
|
- 解析注解进行测试
1 | /* |