你以为你懂Spring AOP?看了这篇底层实现原理,你会惊呆!

开发 前端
AOP 是 IOC 的一个扩展功能,它并不是独立存在的,而是在 IOC 的整个流程中新增了一个扩展点——BeanPostProcessor 接口。

大家好,我是小米。今天我想和大家分享一下 Spring AOP 的底层实现原理,让大家更好地了解 Spring 框架在 AOP 方面的实现方式。

核心思想

首先,需要明确一个概念,AOP 是 IOC 的一个扩展功能,它并不是独立存在的,而是在 IOC 的整个流程中新增了一个扩展点——BeanPostProcessor 接口。在 Spring 框架中,BeanPostProcessor 是一个接口,用于在 Bean 对象创建完成后,在 Bean 初始化之前进行一些自定义的处理操作。因此,我们可以在 BeanPostProcessor 中扩展 AOP 的功能。

AOP概念

AOP 是面向切面编程的一种技术,它主要用来解决一些与业务无关的问题,例如日志记录、性能统计、事务管理等。在 AOP 中,有三个重要的概念:切面(Aspect)、切点(Pointcut)和通知(Advice)。

  • 切面(Aspect):是对一组连接点(Join Point)的通知定义,即它是对切点和通知的封装。
  • 切点(Pointcut):是一组连接点的集合,通知可以被绑定到这些连接点上。在 AOP 中,通过定义切点来选择需要应用通知的连接点。
  • 通知(Advice):是在切点上执行的操作,包括了 before、after、around 等多种类型。

代理对象的创建过程

在 AOP 中,我们通过动态代理来实现增强。代理对象的创建过程包括三个步骤:advice、切面、切点。

  • 通知:即需要执行的增强方法。
  • 切面:切面是一个包含切点和通知的对象,它将切点和通知组合在一起。
  • 切点:切点是一组连接点的集合,它用来定义哪些方法需要被增强。

通过JDK或CGLIB的方式来生成代理对象

在Spring中,当需要为一个类创建代理对象时,Spring会根据类是否实现了接口来选择使用JDK动态代理还是CGLIB动态代理。如果实现了接口,则使用JDK动态代理,否则使用CGLIB动态代理。使用JDK动态代理的代理对象实现了目标类所实现的接口,而使用CGLIB动态代理的代理对象继承了目标类。

执行方法调用时的实现原理

在执行方法调用的时候,会调用到生成的字节码文件中,直接会找到
DynamicAdvisoredInterceptor类的intercept方法,从此开始执行增强逻辑。intercept方法中,会先根据连接点的类型(例如before、after、around等)执行不同的增强方法,然后再调用原始方法。在调用原始方法之前和之后,还会执行一些其他的逻辑,例如事务管理等。

总结

Spring AOP的底层实现原理主要是基于代理模式来实现的。在代理对象的创建过程中,通过组合切面、切点和通知,实现了增强方法的动态注入。在执行方法调用的时候,通过调用
DynamicAdvisoredInterceptor类的intercept方法来实现增强逻辑。

END

通过了解Spring AOP的底层实现原理,我们可以更好地理解Spring框架的AOP功能,从而更好地应用它来解决实际问题。同时,在编写AOP代码时,也需要注意一些细节,例如选择合适的切点、通知类型等,以保证AOP代码的正确性和效率。

责任编辑:武晓燕 来源: 今日头条
相关推荐

2019-01-30 13:44:34

JVM内存服务器

2012-06-20 10:47:25

Team Leader

2024-09-26 14:48:35

SpringAOP范式

2020-05-20 22:13:26

JVM加载机制虚拟机

2019-08-28 15:48:37

Web缓存PWA

2019-01-10 16:52:26

华为

2021-05-06 15:59:27

Linux性能优化

2022-04-26 08:41:54

JDK动态代理方法

2023-08-04 09:43:16

Socket编程Python

2016-01-07 11:18:50

用户画像

2018-03-19 10:39:28

Java序列化对象

2015-06-04 13:19:53

戴尔云计算

2023-10-29 08:35:47

AndroidAOP编程

2024-03-22 18:40:27

脑机接口机器人人工智能

2017-07-27 09:53:34

spring AopspringCIO

2016-08-19 01:59:22

APPAPM用户

2020-05-25 09:22:57

Linux 命令行

2012-05-08 08:55:56

2022-05-11 09:09:42

用户客户

2019-05-13 14:17:06

抓包Web安全漏洞
点赞
收藏

51CTO技术栈公众号