之前理解了 Spring IOC,自我感觉还可以,但是理解AOP感觉挺难的,结合最近的看的书,稍微总结一下。
什么是AOP
AOP的全称是 Aspect-Oriented Programming,即面向切面编程(也称面向方面编程)。它是面向对象编程(OOP)的一种补充,目前已成为一种比较成熟的编程方式。
在传统的业务处理代码中,通常会进行事务处理、日志记录等操作。虽然OOP可以通过组合或者继承的方式来达到代码的重用,但如果要实现某个功能(如日志记录),同样的代码仍然会分散到各个方法中。这样如果想要关闭某个功能,或者对其进行修改,就必须要修改所有的相关方法。这不但增加了开发人员的工作量,而且提高了代码的出错率。
为了解决这一问题,AOP的思想随之产生。AOP采取横向抽取机制,将分散在各个方法中的重复代码提取出来,然后在程序编译或运行时,再将这些提取出来的代码应用到需要执行的地方。这种采用横向抽取机制的方式,采用传统的OOP思想显然是无法办到的,因为OOP只能实现父子关系的纵向的重用。虽然AOP是一种新的编程思想,但不是OOP的替代品,它只是OOP的延伸和补充。
在AOP思想中,类与切面的关系如图所示:
从图中可以看到,通过Aspect(切面)分别在Class1和Class2的方法中加入了事务、日志、权限、异常等功能。
AOP的使用,使开发人员在编写业务逻辑时可以专心于核心业务,而不是过多的关注于其他业务逻辑的实现,这不但提高了开发效率,而且增强了代码的可以维护性。
目前最流行的AOP框架有两个,分别是 Spring AOP 和 AspectJ。 Spring AOP使用纯Java实现,不需要专门的编译过程和类加载器,在运行期间通过代理方式向目标织入增强的代码。
AspectJ 是一个基于Java语言的AOP框架,从 Spring 2.0 开始, Spring AOP 引入了对AspectJ的支持,AspectJ扩展了Java语言,提供了一个专门的编译器,在编译时提供横向代码的织入。
AOP术语
学习AOP之前,先了解一下有关AOP的一些术语:
-
Aspect(切面):在实际应用中,切面通常是指封装的用于横向插入系统功能(如事务)的类,如上图的Aspect。该类要被 Spring 容器识别为切面,需要在配置文件中通过
元素指定。 -
Joinpoint(连接点):在程序执行过程中的某个阶段点,它实际上是对象的一个操作,例如方法的调用或异常的抛出。在 Spring AOP中,连接点就是指方法的调用。
-
Pointcut(切入点):是指切面与程序流程的交叉点,即那些需要处理的连接点,如下图程序流程所示。通常在程序中,切入点指的是类或方法名,如某个通知要应用到所有以add开头的方法中,那么所有满足这一规则的方法都是切入点。
-
Advice(通知/增强处理):AOP 框架在特定的切入点执行的增强处理,即在定义好的切入点处所要执行的程序代码。可以将其理解为切面类中的方法,它是切面的具体实现。
-
Target Object(目标对象):是指所有被通知的对象,也称为被增强对象。如果AOP框架采用的是动态的AOP实现,那么该对象就是一个被代理对象。
-
Proxy(代理):将通知应用到目标对象之后,被动态创建的对象。
-
Weaving(织入):将切面代码插入到目标对象上,从而生成代理对象的过程。
小结
通过上述的理解,感觉AOP就像是为了更好复用代码,将一些分散的代码能够更好的利用和维护。