Java 自定义注解
Java 自定义注解
1、简介
注解是一种能被添加到 java 源代码中的元数据,方法、类、参数和包都可以用注解来修饰。注解可以看作是一种特殊的标记,可以用在方法、类、参数和包上,程序在编译或者运行时可以检测到这些标记而进行一些特殊的处理。
2、元注解
元注解的作用就是负责注解其他注解。Java5.0 定义了 4 个标准的 meta-annotation 类型,它们被用来提供对其它 annotation 类型作说明。Java5.0 定义的元注解:
1.@Target,
2.@Retention,
3.@Documented,
4.@Inherited
这些类型和它们所支持的类在 java.lang.annotation 包中可以找到。下面我们看一下每个元注解的作用和相应分参数的使用说明。
2.1、@Target
表明该注解可以应用的 java 元素类型:
Target 类型 | 描述 |
ElementType.TYPE | 应用于类、接口(包括注解类型)、枚举 |
ElementType.FIELD | 应用于属性(包括枚举中的常量) |
ElementType.METHOD | 应用于方法 |
ElementType.PARAMETER | 应用于方法的形参 |
ElementType.CONSTRUCTOR | 应用于构造函数 |
ElementType.LOCAL_VARIABLE | 应用于局部变量 |
ElementType.ANNOTATION_TYPE | 应用于注解类型 |
ElementType.PACKAGE | 应用于包 |
ElementType.TYPE_PARAMETER | 1.8 版本新增,应用于类型变量 |
ElementType.TYPE_USE | 1.8 版本新增,应用于任何使用类型的语句中(例如声明语句、泛型和强制转换语句中的类型) |
2.2、@Retention
表明该注解的生命周期
生命周期类型 | 描述 |
RetentionPolicy.SOURCE | 编译时被丢弃,不包含在类文件中 |
RetentionPolicy.CLASS | JVM 加载时被丢弃,包含在类文件中,默认值 |
RetentionPolicy.RUNTIME | 由 JVM 加载,包含在类文件中,在运行时可以被获取到 |
2.3、@Document
表明该注解标记的元素可以被 Javadoc 或类似的工具文档化。
2.4、@Inherited
表明使用了 @Inherited 注解的注解,所标记的类的子类也会拥有这个注解。
3、自定义注解
- 修饰符: 访问修饰符必须为 public, 不写默认为 pubic;
- 关键字: 关键字为 @interface;
- 注解名称: 注解名称为自定义注解的名称,使用时还会用到;
- 注解内容: 注解中内容,对注解的描述。
3.1、自定义 @MyController 注解:
/**
* @Author dw
* @ClassName MyController
* @Description 自定义注解, 可用于类、方法上
* @Date 2022/1/10 21:33
* @Version 1.0
*/
@Documented
@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
public @interface MyController {
String value() </span><span style="color: rgba(0, 0, 255, 1)">default</span> ""<span style="color: rgba(0, 0, 0, 1)">;
String des() </span><span style="color: rgba(0, 0, 255, 1)">default</span> "我是一个自定义注解"<span style="color: rgba(0, 0, 0, 1)">;
}
3.2、在类上使用自定义的注解
/**
* @Author dw
* @ClassName TestAnnotation
* @Description 自定义注解使用
* @Date 2022/1/10 21:42
* @Version 1.0
*/
@MyController(value = "我是指定注解 value")
public class TestAnnotation {
</span><span style="color: rgba(0, 0, 255, 1)">public</span> <span style="color: rgba(0, 0, 255, 1)">static</span> <span style="color: rgba(0, 0, 255, 1)">void</span><span style="color: rgba(0, 0, 0, 1)"> main(String[] args) {
</span><span style="color: rgba(0, 0, 255, 1)">try</span><span style="color: rgba(0, 0, 0, 1)"> {
TestAnnotation testAnnotation </span>= <span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> TestAnnotation();
Class</span><? <span style="color: rgba(0, 0, 255, 1)">extends</span> TestAnnotation> aClass =<span style="color: rgba(0, 0, 0, 1)"> testAnnotation.getClass();
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">判断person对象上是否有Info注解</span>
<span style="color: rgba(0, 0, 255, 1)">if</span> (aClass.isAnnotationPresent(MyController.<span style="color: rgba(0, 0, 255, 1)">class</span><span style="color: rgba(0, 0, 0, 1)">)) {
System.out.println(</span>"TestAnnotation类上配置了MyController注解!"<span style="color: rgba(0, 0, 0, 1)">);
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">获取该对象上Info类型的注解</span>
MyController myController = aClass.getAnnotation(MyController.<span style="color: rgba(0, 0, 255, 1)">class</span><span style="color: rgba(0, 0, 0, 1)">);
System.out.println(</span>"myController.value :" + myController.value() + ", myController.des:" +<span style="color: rgba(0, 0, 0, 1)"> myController.des());
} </span><span style="color: rgba(0, 0, 0, 1)">
} </span><span style="color: rgba(0, 0, 255, 1)">catch</span><span style="color: rgba(0, 0, 0, 1)"> (Exception e) {
e.printStackTrace();
}
}
}
执行结果如下:
4、Aop 中的应用:
请参考之前的文章:在 Aop 中使用自定义注解