java中注解的原理和实现机制

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/shuaipu813/article/details/52815432

                                            java中注解的实现原理和机制

一.什么是注解:

     注解是标记,也可以理解成是一种应用在类、方法、参数、属性、构造器上的特殊修饰符。注解作用有以下三种:

       第一种:生成文档,常用的有@param@return等。

       第二种:替代配置文件的作用,尤其是在spring等一些框架中,使用注解可以大量的减少配置文件的数量。

       第三种:检查代码的格式,如@Override,标识某一个方法是否覆盖了它的父类的方法。

二.注解的底层实现原理:

       注解的底层也是使用反射实现的,我们可以自定义一个注解来体会下。注解和接口有点类似,不过申明注解类需要加上@interface,注解类里面,只支持基本类型、String及枚举类型,里面所有属性被定义成方法,并允许提供默认值。

       java 5.0开始,在java.lang.annotations中提供了四种元注解,专门注解其他的注解:

    @Target?  — —注解用于什么地方

    TYPE,  //给类(型)注解
    FIELD, //给字段注解,不要忘了,字段可以是对象
    METHOD, //给方法注解
    PARAMETER, //给参数注解
    CONSTRUCTOR, //给构造方法注解
    LOCAL_VARIABLE, //给局部变量注解
    ANNOTATION_TYPE,//给注解注解(这貌似把自己不当类来看)
    PACKAGE, //给包注解

   @Retention — —注解运行状态

   SOURCE, //源码状态运行,
   CLASS, //编译类文件时运行
   RUNTIME //运行时运行

   @Documented — — 生成说明文档,添加类的解释 

   @Inherited — —允许子类继承父类中的注解。

   我们自定义一个注解来感受下:

定义注解类:

  @Target({ElementType.TYPE})
  @Retention(RetentionPolicy.RUNTIME)
  @Documented
  public @interface User {
     String name() default "张三";
  }

由于我们的注解是类注解,所以我们创建一个类

@User
 public class test {
}

到了这里,注解可能还没起什么作用。我们需要通过反向代理去读取类中定义的注解,读出来使用就简单了。

创建测试类,来读取:

public class testamin {
public static void main(String[] args) throws ClassNotFoundException{
        Class<?> classTest=Class.forName("com.test.test");
        Annotation[] ann=classTest.getAnnotations();
        for(Annotation aa:ann){
            User u=(User)aa;
            System.out.println(u.name());
        }
     }
}


控制台输出了我们定义的注解,注解的初识就介绍到这里吧。

    

猜你喜欢

转载自blog.csdn.net/shuaipu813/article/details/52815432