首页 > 技术文章 > SpringBoot项目中自定义注解的使用

zfyer 2020-02-21 14:07 原文

1.定义注解接口

  1. @Documented

  2. @Retention(RUNTIME)

  3. @Target(METHOD)

  4. public @interface MyLog {

  5.    String value() default "日志注解";

  6. }

@Documented 注解: Documented 注解表明这个注解应该被 javadoc工具记录. 默认情况下,javadoc是不包括注解的.

但如果声明注解时指定了 @Documented,则它会被 javadoc 之类的工具处理, 所以注解类型信息也会被包括在生成的文档中

@Inherited 注解: 它指明被注解的类会自动继承. 更具体地说,如果定义注解时使用了 @Inherited 标记

然后用定义的注解来标注另一个父类, 父类又有一个子类(subclass),则父类的所有属性将被继承到它的子类中

  • @Target(ElementType.TYPE) //接口、类、枚举、注解

  • @Target(ElementType.FIELD) //字段、枚举的常量

  • @Target(ElementType.METHOD) //方法

  • @Target(ElementType.PARAMETER) //方法参数

  • @Target(ElementType.CONSTRUCTOR) //构造函数

  • @Target(ElementType.LOCAL_VARIABLE)//局部变量

  • @Target(ElementType.ANNOTATION_TYPE)//注解

  • @Target(ElementType.PACKAGE) ///包

  • 1.RetentionPolicy.SOURCE——这种类型的Annotations只在源代码级别保留,编译时就会被忽略

    2.RetentionPolicy.CLASS——这种类型的Annotations编译时被保留,在class文件中存在,但JVM将会忽略

  • 3.RetentionPolicy.RUNTIME——这种类型的Annotations将被JVM保留,所以他们能在运行时被JVM或其他使用反射机制的代码所读取和使用.

推荐阅读