当前位置 博文首页 > 文章内容

    Java注解和反射

    作者: 栏目:未分类 时间:2020-08-07 18:00:35

    本站于2023年9月4日。收到“大连君*****咨询有限公司”通知
    说我们IIS7站长博客,有一篇博文用了他们的图片。
    要求我们给他们一张图片6000元。要不然法院告我们

    为避免不必要的麻烦,IIS7站长博客,全站内容图片下架、并积极应诉
    博文内容全部不再显示,请需要相关资讯的站长朋友到必应搜索。谢谢!

    另祝:版权碰瓷诈骗团伙,早日弃暗投明。

    相关新闻:借版权之名、行诈骗之实,周某因犯诈骗罪被判处有期徒刑十一年六个月

    叹!百花齐放的时代,渐行渐远!



    注解和反射

    Java所有的框架底层是通过注解和反射实现

    Java.Annotation

    • Annotation是从JDK5.0开始引入的新技术

    • Annotation的作用:

      • 不是程序本身,可以对程序作出解释。(这一点和注释(comment)没什么区别)

      • 可以被其他程序(比如:编译器等)读取。

    • Annotation的格式:

      • 注解是以"@注释名"在代码中存在的,还可以添加一些参数值,例如:@SupperessWarnings(value="unchecked")。

    • Annotation在那里使用?

      • 可以附加在package,class,method,field等上面,相当于给他们添加了额外的辅助信息,我们可以通过反射机制编程实现对这些数据的访问。

         

    内置注解

     

    元注解

    • 元注解的作用就是负责注解其他注解,Java定义了4个标准meta-annotation类型,它们被用来提供对其他annotation类型做说明

    • 这些类型和它们所支持的类在java.lang.annotation包中可以找到(@Target,@Retention,@Docunmented,@Inherited)

      • @Target:用于描述注解的使用范围(即:被描述的注解可以用在什么地方)

      • @Retendtion:表示需要在什么级别保存该注释信息,用于描述注解的生命周期

        • (SOURCE<CLASS<RUNTIME)

      • @Document:说明该注解被包含在javadoc中

      • @Innherited:说明子类可以继承父类中的该注解

     package com.zhou.annotation;
     import java.lang.annotation.*;
     
     //测试元注解
     @MyAnnotation
     public class Test02 {
     
         public void test(){}
     
     }
     
     //定义一个注解
     //Target 表示我们的注解可以用在哪些地方
     //Retention 表示我们的注解在什么地方才有效 runtime>class>sources
     //Documented 表示是否将我们的注解生成在JAVAdoc中
     //Inherited 子类可以继承父类的注解
     @Target(value ={ElementType.METHOD,ElementType.TYPE} )
     @Retention(value= RetentionPolicy.RUNTIME)
     @Documented
     @Inherited
     @interface MyAnnotation{
     }

     

    自定义注解

    • 使用@interface自定义注解时,自定继承了java.lang.annotation.Annotation

     

    • 分析:

      • @interface用来声明一个注解,格式:public @interface 注解名{定义内容}

      • 其中的每一个方法实际上是声明了一个配置参数。

      • 方法的名称就是参数的名称

      • 返回值类型就是参数的类型(返回值只能是基本类型,class,String,enum)

      • 可以通过default来声明参数的默认值

      • 如果只有一个参数成员,一般参数名为value

      • 注解元素必须要有值,我们定义注解元素时,经常使用空字符串,作为默认值。

     package com.zhou.annotation;
     import java.lang.annotation.ElementType;
     import java.lang.annotation.Retention;
     import java.lang.annotation.RetentionPolicy;
     import java.lang.annotation.Target;
     
     //自定义一个注解
     public class Test03 {
         //注解可以显式赋值,如果没有默认值,我们就必须给注解赋值
         @MyAnnotation2(name="zhouyang",schools = {"西北工业大学","华南理工大学"})
         public void test(){}
     
         @MyAnnotation3("xiixo")
         public void test2(){}
     }
     
     @Target(value = {ElementType.TYPE,ElementType.METHOD})
     @Retention(RetentionPolicy.RUNTIME)
     @interface MyAnnotation2{
         //注解的参数:参数的类型+参数名()
         String name() default "";
         int age() default 0;
         int id() default -1;//如果默认值为-1,代表不存在,indexof,如果找不到就返回-1
         String[] schools();
     }
     
     @Target(value = {ElementType.TYPE,ElementType.METHOD})
     @Retention(RetentionPolicy.RUNTIME)
     @interface MyAnnotation3{
         String value();
     }