什么是AOP
AOP(Aspect Oriented Programming)意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。
AOP是软件开发思想发展到一定阶段的产物,但AOP的出现并不是要完全替代OOP,而仅作为OOP的有益补充。
AOP是有特定的应用场合的,它只适合那些具有横切逻辑的应用场合,如性能检测、访问控制、事务管理及日志记录等。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。
AOP是一种思想,不同的厂商或企业可能有不同的实现方式。在AOP联盟定义的AOP体系结构下有很多的实现者,例如:AspectJ、AspectWerkz、JBoss AOP、Spring AOP等。
Spring AOP 是AOP在Spring中的具体实现,它是构成Spring框架的另一个重要基石。Spring AOP构建于IoC之上,统一于Spring容器中。
AOP术语
1、 连接点(Joinpoint):一个类或一段程序代码拥有一些具有边界性质的特定点。
Spring只支持方法的连接点,即仅能在方法调用前、方法调用后、方法抛出异常及方法调用前后这些程序执行点织入增强。
连接点确定两个信息:1、用方法表示的程序执行点;2、用相对位置表示的方位。
Spring使用切点对执行点进行定位,而方位则在增强类型中定义。
2、 切点(Pointcut):AOP通过“切点”定位特定的连接点。
在Spring中,切点通过org.springframework.aop.Pointcut接口进行描述,它使用类和方法作为连接点的查询条件,Spring AOP的规则解析引擎负责解析切点所设定的查询条件,找到对应的连接点。
因为连接点是方法执行前、执行后等包括方位信息的具体程序执行点,而切点只定位到某个方法,所以如果希望定位到具体的连接点,还需要通过方位的信息。
3、增强(Advice):增强是织入目标类连接点上的一段程序代码。
在Spring中,增强除用于描述一段程序代码外,还拥有另一个和连接点相关的信息,这便是执行点的方位。
结合执行点的方位信息和切点信息,就可以找到特定的连接。
正因为增强既包含用于添加到目标连接点上的一段执行逻辑,又包含用于定位连接点的方位信息,所以Spring所提供的增强接口都是带方位名的,如:BeforeAdvice、AfterReturningAdvice、ThrowsAdvice等。
4、目标对象(Target):增强逻辑的织入目标类。
5、引介(Introduction):引介是一种特殊的增强,它为类添加一些属性和方法。
6、织入(Weaving):织入是将增强添加到目标类的具体连接点上的过程。
AOP有3种织入方式:
1)编译期织入,需要使用特殊的Java编译器
2)类装载期织入,需要使用特殊的Java编译器
3)动态代理织入,在运行期为目标类添加增强生成子类的过程
7、代理(Proxy):一个类被AOP织入增强后,就产生了一个结果类,它是融合了原类和增强逻辑的代理类。根据代理方式的不同,代理类既可以是和原类具有相同接口的类,也可能就是原类的子类。
8、切面(Aspect):切面由切点和增强(引介)组成,它既包括横切逻辑的定义,也包括连接点的定义。
Spring AOP就是负责实施切面的框架。
代理
Spring AOP的底层就是通过使用JDK或CGLib动态代理技术为目标Bean织入横切逻辑的。
Spring AOP通过Pointcut(切点)指定在哪些类的哪些方法上织入横切逻辑,通过Advice(增强)描述横切逻辑和方法的具体织入点(方法前、方法后、方法的两端等)。此外,Spring通过Advisor(切面)将Pointcut和Advice组装起来。有了Advisor的信息,Spring就可以利用JDK或CGLib动态代理技术采用统一的方式为目标Bean创建织入切面的代理对象。
JDK动态代理 vs CGLib动态代理
- CGlib所创建的动态代理对象的性能高于JDK所创建的动态代理对象(约10倍)
- CGLib在创建代理对象时所花费的时间比JDK动态代理多(约8倍)
- 对于Singleton的代理对象或者具有实例池的代理,因为无需频繁的创建代理对象,所以比较适合采用CGLib动态代理技术;反之则适合采用JDK动态代理技术。
原文地址:https://www.cnblogs.com/yang21/p/9968971.html