反射+自定义注解

本文介绍了Java中的反射机制和自定义注解。反射允许在运行时动态获取类信息并操作,用于框架扩展,如Spring的IOC。它有优缺点,如提高灵活性但消耗资源。注解用于添加元数据,元注解如@Target、@Retention定义其使用和保留策略。注解通过反射+AOP实现功能,例如自定义限流框架。
摘要由CSDN通过智能技术生成

反射和自定义注解

反射

1、什么是反射

2、反射的优缺点

3、反射的用途/反射应用场景

4、反射API的内容

5、反射API的使用

6、反射越过泛型检查

7、如何在运行时获取泛型类型

注解

1、什么是注解/元注解

2、[如何获取注解信息](#2.3 获取注解信息)

3、注解的属性

4、[注解生效的原理自定义限流框架](#2.5 注解如何生效)

1、反射机制

  • 什么是反射

通过反射,我们可以在运行时获得程序或程序集中每一个类型的成员和成员的信息。程序中一般的对象的类型都是在编译期就确定下来,而Java反射机制可以动态地创建对象并调用其属性,这样的对象的类型在编译器是未知的

  • Java反射机制的核心是在程序运行时动态加载类获取类的详细信息,从而操作类或对象的属性和方法。本质是JVM得到class对象后,再通过class对象进行反编译,从而获取对象的各种信息。
  • Java属于先编译再运行的语言,程序中对象的类型在编译期就确定下来,而当程序在运行时可能需要动态加载某些类,这些类因为之前用不到,所以没有被加载到JVM。通过反射,可以在运行时动态创建对象并调用其属性,不需要提前在编译期知道运行的对象是哪个类型。

使用反射机制可以动态获取当前class的信息,比如方法的信息、注解信息、方法的参数、属性等

第三方框架–创建对象 不是直接new 而是通过反射机制创建

反射的目的:提供开发者能够更好地封装框架实现扩展功能

1.1反射的优缺点
  • 优点:提供开发者能够更好地封装框架实现扩展功能

    ​ 在运行时获得类的各种内容,进行反编译,对于Java这种先编译在运行的语言,能够让我们很方便的创建灵活的代码,这些代码可以在运行时装配,无需在组件之间进行源代码的链接,更加容易实现面向对象

  • 缺点:

    • (1)反射会消耗一定的系统资源,所以如果不需要动态创建一个对象,就不必要用反射
    • (2)反射调用方法时可以忽略权限检查,因此可能会破坏封装性而导致安全问题
      • 一个类中,定义的私有属性或方法, 反射机制可以越过权限破解私有属性
1.2反射的用途/应用场景
  1. 通过反射机制访问java对象的属性、方法、构造方法等
  2. JDBC加载驱动链接 class.forName
  3. Spring容器框架IOC实例化对象
  4. 自定义注解生效(反射+AOP)
  5. 第三方核心框架 (Mybatis的ORM思想)
1.3反射API的内容

Class类 代表类的实体,在运行的Java应用程序中表示类和接口

Field类 代表类的成员变量(成员变量也称为类的属性)

Method类 代表类的方法

Constructor类 代表类的构造方法

1.getField、getMethod和getCostructor方法可以获得指定名字的域、方法和构造器。

2.getFields、getMethods和getCostructors方法可以获得类提供的public域、方法和构造器数组,其中包括超类的共有成员。

3.getDeclaredFields、getDeclaredMethods和getDeclaredConstructors方法可以获得类中声明的全部域、方法和构造器,其中包括私有和受保护的成员,但不包括超类的成员。

1.4反射技术常用API
  • 1.4.1获取class
    • 任何数据类型(包括基本数据类型)都有一个“静态”的class属性
    • 运行期间,一个类只有一个Class对象产生
        //1、获取class的方法
        /*
        ①直接通过类名获取 User.class
        ②Class.forName("类的完整路径名")  类的完整路径名=包名+类名
        ③实体对象.getClass()
        * */
        //第一种
        Class<User> userClass1 = User.class;
        //第二种
        Class<User> userClass2 = (Class<User>) Class.forName("反射.User");
        //第三种
        User user=new User();
        Class<User> userClass3= (Class<User>) user.getClass();
		// userClass1==userClass2==userClass3
  • 1.4.2反射执行构造函数

    • 执行无参构造函数(通过 Class.newInstance() )

      //2、默认执行无参构造函数
      User user1 = (User) userClass1.newInstance();
      
    • 执行有参构造函数 (借助Constructor对象)

      //3、执行有参构造函数
      Constructor<User> con=userClass1.getConstructor(String.class,Integer.class);
      User user2=con.newInstance("Beau",23);
      
  • 1.4.3反射执行给属性赋值

    • 反射执行给公有属性赋值 不加Declared(同时也可以获取超类的属性)

      Field nameField = userClass1.getField(
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值