SpringAOP术语详解

如学习电学先学习电阻,电压,电容等专业术语一样,AOP也又一些自己的行话,为了更了解AOP,我应该学习一下相关重要术语。

(1)链接点(Jionpiont)

程序执行的某个特定位置: 如类开始初始化前,类初始化后, 类某个方法调用前、调用后、方法抛出异常后。一个类或一段程序代码拥有一些具有边界性质的特点。这些代码中的特定点就称为“”“ 连接点”。Spring方法的连接点,即只能在方法调用前、调用后、方法抛出异常时以及方法调用前后这些程序执行点织增强.。我们知道黑客攻击系统需要找到突破口,没有突破口就无法进行攻击。从某种程度上讲,AOP是一个黑客(因为它要想目标类中嵌入额外的代码逻辑),链接点就是AOP向目标类打入楔子的候选点。
连接点由两个信息确定:第一个是用方法表示程序的执行点;第二是用相对点表示的方位。如在Test,foo()执行前的连接点,之心点为Test.foo(),方位为该方法执行前的位置。Sping使用切点对执行点进行定位,而方位则在增强类型中定义。

(2)切点(Pointcut)

每个程序类都有多个连接点,如一个拥有两个方法的类,这两个方法都是连接点,即链接点是程序类中客观存在的事物。但在这为数总多的连接点中,如何定位到某个感兴趣的连接点上呢?AOP通过“切点”定位特定的连接点。通过数据库查询的概念来理解切点和连接点再适合不过的了:连接点相当于数据库的记录,而切点相当于查询条件。切点跟连接点不是一对一的关系,一个切点可以匹配多个连接点。
在Spring中,切点用过org.springframework.aop.Pointcut接口进行描述,它使用类和方法作为连接点的查询条件,Spring AOP的规则解析引擎负责解析切点所设定的查询条件,找到对应的链接点。其实确切的说,不能称之为查询连接点,因为连接点为方法查询前、后、异常抛出时等包括方位信息的具体程序执行点,而切点定位到某个方法上,所以如果希望定位到具体连接点上,还需要提供具体的方位信息。

(3)增强(Advice)

增强是织入到目标类连接点上的一段程序代码。是不是觉得AOP越来越像黑客了?这不是往业务类中织入木马吗?我们大可可以根据这一思路去理解增强,因为这样更形象易懂。在Spring中,增强除了描述一段代程序码外,还拥有另一个和连接点相关的信息,这便是执行点的方位。结合执行点的方位信息和切点信息,我们就可以找到特定的连接点了!正因为增强包含了用于添加到目标连接点上的一段执行逻辑,有包含了定位连接点的方位信息,所以Spring所提供的增强接口都是带方位名的:BeforAdvice、AfterReturningAdvice、ThrowsAdvice等。BeforAdvice表示方法调用前的位置,而AfterReturningAdvice表示访问返回后的位置。所以要结合切点和增强两者一起上阵才能确定一特定的连接点并实施增强逻辑。

(4)目标对象(Target)

增强逻辑的织入目标类。如果没有AOP,目标业务类需要自己实现所以逻辑,就如ForumService所示。在AOP的帮助下,ForumService只实现那些非横切逻辑的程序逻辑,而性能性能监视和事务管理等这些横切逻辑则可以使用AOP动态织入到特定的链接上。

(5)引介(Inroduction)

引介是一种特殊的增强,它为类添加一些属性和方法。这样,即使一个业务类原本没有实现某个接口,通过AOP的引介功能,我们可以动态地为该业务类添加接口的实现逻辑,让业务类成为这个接口的实现类。

(6)织入(Weaving)

织入是将增强添加到目标类具体连接点上的过程,AOP像一台织布机,将目标类、增强或者引介通过AOP这台织布机天衣无缝地编织在一起。我们不能不说“织入”这个词用得太精辟了。根据不同的实现技术,AOP有三种织入的方式:
1)编译期织入,这要求使用特殊的Java编译器;
2)类装载期织入,这要求使用特殊的类装载器;
3)动态代理织入,在运行期为目标类添加增强生成子类的方式。
Spring采用动态代理织入,而AspectJ采用编译期织入和类装载期织入。

(7)代理(Porxy)

一个类被AOP织入增强后,就产生一个结果类,它是融合了原类和增强逻辑代理类。根据不同的代理方式,代理类既可能是和原类具有相同接口的类,也可能就是原类的子类,所以我们可以采用调用原类相同的方式调用代理类。

(8)切面(Aspect)

切面有切点和增强(引介)组成,它既包括了横切逻辑的定义,也包括了连接点的定义,SpringAOP就是负责实施切面的框架,它将切面所定义的横切逻辑织入到切面所指定的连接点中。


AOP的工作重心在于如何将增强应用到目标对象连接点上,这里首先包括 两个工作:第一,如何通过切点和增强定位到连接点上第二,如何在增强中编写切面的代码。