• 手撕Java--spring注解(个人感觉好玩,常用的一些注解)


    一直很好奇这些Java中注解是怎么实现的,所以就去了解了一番,做此记录。

    1.元注解(meta-annotations),可以理解为为其他注解做注解。

    1.  @Target:描述注解的使用范围,主要返回了枚举类ElementType的值,其中ElementType的值主要有(最后两个为Java8新增的):
      1. TYPE:说明该注解只能被声明在一个类上。

      2. FIELD:说明该注解只能被声明在一个类的字段上。

      3. METHOD:说明该注解只能被声明在一个类的方法上。

      4. PARAMETER:说明该注解只能被声明在一个方法参数上。

      5. CONSTRUCTOR:说明该注解只能声明在一个类的构造方法上。

      6. LOCAL_VARIABLE:说明该注解只能声明在一个局部变量上。

      7. ANNOTATION_TYPE:说明该注解只能声明在一个注解类型上。

      8. PACKAGE:说明该注解只能声明在一个包名上。

      9. TYPE_PARAMETER:说明该注解只能申明在一个参数类型上。

      10. TYPE_USE:类型的作用。

    @Target()可以存放数组默认值为任何元素。如下图所示,

    @Documented
    @Retention(RetentionPolicy.RUNTIME)
    @Target(ElementType.ANNOTATION_TYPE)
    public @interface Target {
        /**
         * Returns an array of the kinds of elements an annotation type
         * can be applied to.
         * @return an array of the kinds of elements an annotation type
         * can be applied to
         */
        ElementType[] value();
    }

     2.@Retention:定义注解的有效时间,会返回一个RetentionPolicy的值,主要有三个值,

           作用:表示需要在什么级别保存该注释信息,用于描述注解的生命周期(即:被描述的注解在什么范围内有效)

    @Documented
    @Retention(RetentionPolicy.RUNTIME)
    @Target(ElementType.ANNOTATION_TYPE)
    public @interface Retention {
        /**
         * Returns the retention policy.
         * @return the retention policy
         */
        RetentionPolicy value();
    }
    public enum RetentionPolicy {
        /**
         * Annotations are to be discarded by the compiler.
         */
        SOURCE,
    
        /**
         * Annotations are to be recorded in the class file by the compiler
         * but need not be retained by the VM at run time.  This is the default
         * behavior.
         */
        CLASS,
    
        /**
         * Annotations are to be recorded in the class file by the compiler and
         * retained by the VM at run time, so they may be read reflectively.
         *
         * @see java.lang.reflect.AnnotatedElement
         */
        RUNTIME
    }
    • SOURCE:在源文件中有效(即源文件保留)
    • CLASS:在class文件中有效(即class保留)
    • RUNTIME:在运行时有效(即运行时保留)

     3.@Documented:只是起一个标记的作用,可以被javadoc归档,只是一个标记注解,没有成员。

     4.@Inherited:一个标记注解,@Inherited阐述了某个被标注的类型是被继承的。如果一个使用了@Inherited修饰的annotation类型被用于一个class,则这个annotation将被用于该class的子类。

    5.@AliasFor:作为互为别名使用,有时候两个属性起同样的作用,为了防止冲突,就需要用到这个注解。如下是远吗,可以看到方法名和属性名是倒过来的。

    @Retention(RetentionPolicy.RUNTIME)
    @Target({ElementType.METHOD})
    @Documented
    public @interface AliasFor {
        @AliasFor("attribute")
        String value() default "";
    
        @AliasFor("value")
        String attribute() default "";
    
        Class<? extends Annotation> annotation() default Annotation.class;
    }

    自定义注解

           使用@interface自定义注解时,自动继承了java.lang.annotation.Annotation接口,由编译程序自动完成其他细节。在定义注解时,不能继承其他的注解或接口。@interface用来声明一个注解,其中的每一个方法实际上是声明了一个配置参数。方法的名称就是参数的名称,返回值类型就是参数的类型(返回值类型只能是基本类型、Class、String、enum)。可以通过default来声明参数的默认值。

        格式:public @interface 注解名 {定义体}

    可支持数据类型:

        1.所有基本数据类型(int,float,boolean,byte,double,char,long,short)
        2.String类型
        3.Class类型
        4.enum类型
        5.Annotation类型
        6.以上所有类型的数组

    Annotation类型里面的参数该怎么设定: 
      第一,只能用public或默认(default)这两个访问权修饰.例如,String value();这里把方法设为defaul默认类型;   
     第二,参数成员只能用基本类型byte,short,char,int,long,float,double,boolean八种基本数据类型和 String,Enum,Class,annotations等数据类型,以及这一些类型的数组.例如,String value();这里的参数成员就为String;  
      第三,如果只有一个参数成员,最好把参数名称设为"value",后加小括号.例:下面的例子FruitName注解就只有一个参数成员。

    链接:

    annotation(@Retention@Target)详解https://www.cnblogs.com/gmq-sh/p/4798194.html

    Spring中的@AliasFor标签:https://blog.csdn.net/wolfcode_cn/article/details/80654730

  • 相关阅读:
    iOS 性能调优
    Google Nexus 5x Android 7.0 Root
    Android库的标准化(不断更新中)
    Firefox实用插件记录
    关于WordPress搬家方法步骤的整理
    eclipse搭建servlet项目
    Eclipse的FindBugs插件
    常用 Java 静态代码分析工具的分析与比较
    JSONObject简介
    New XAMPP security concept:错误解决方法
  • 原文地址:https://www.cnblogs.com/baichendongyang/p/13235542.html
Copyright © 2020-2023  润新知