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、自定义注解

  1. 修饰符: 访问修饰符必须为 public, 不写默认为 pubic;
  2. 关键字: 关键字为 @interface;
  3. 注解名称: 注解名称为自定义注解的名称,使用时还会用到;
  4. 注解内容: 注解中内容,对注解的描述。

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>&lt;? <span style="color: rgba(0, 0, 255, 1)">extends</span> TestAnnotation&gt; 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 中使用自定义注解