最近在看《Spring揭秘》里面AOP部分,利用最近两三天的上班空余时间来简单总结一下吧。
- AOP是什么
- AOP的实现
- AOP在Java上的实现
- AOP织入器
AOP是什么?
AOP全称"Aspect-Oriented Programming",意为面向切面编程。使用AOP,我们可以对类似于Logging和Security等系统需求进行模块化的组织,简化系统需求与实现之间的对比关系,进而使得整个系统的实现更具有模块化
所以说,个人理解AOP其实算一种开发思想,在我们的软件开发中,通过引入所谓切面
的概念来将日志记录,权限控制等一些与业务逻辑关系不算太大的其他逻辑操作隔离开,从而使得业务逻辑和其余的逻辑各自能够更好地被组织,维护,更具有模块化。
AOP的实现
AOL
AOP是一种理念,需要一种方式来实现该理念。那么实现AOP的语言就成为AOL,即Aspect-Oriented Language。那么AOP都有哪些语言实现方式呢?
- AspectJ(Java)
- AspectC
- AspectC++
- Aspect.Net
- AspectL(Lisp)
- AspectPHP
基本实现原理
- 静态AOP
以AspectJ为代表,将实现后的Aspect编译并织入到系统的静态类中。比如,AspectJ会使用ajc编译器将各个Aspect以java字节码的形式编译到系统的各个功能模块中,以达到融合Aspect和Class的目的。
静态AOP的优点:
Aspect直接以Java字节码的形式编译到Java类中,Java虚拟机可以像通常一样加载Java类运行,不会对整个系统的运行造成任何的性能损失。
缺点:
灵活性不够。如果切点需要个改变,则需要重新修改代码,重新编译织入到系统中。
- 动态AOP
动态AOP的织入过程在系统运行开始之后进行,而不是预先编译到系统类中,而且织入的信息大都采用外部XML文件格式保存,可以在调整织入点以及织入逻辑单元的同时,不必变更系统其他模块,甚至在系统运行的时候,也可以动态地更改织入逻辑。
动态AOP的代表有JBoss AOP、Spring AOP等框架。
AOP在Java上的实现
1. 动态代理
2. 动态字节码增强
3. 自定义类加载器
4. Java代码生成
5. AOL扩展
AOP中的关键字
-
Joinpoint: 代表要织入到系统中的执行点。
常见的织入点有: 方法调用、方法执行、构造方法调用、构造方法执行、字段设置、字段获取、异常处理执行、类初始化(静态类型、静态块)。
-
PointCut: 代表的是Joinpoint的表述方式,描述要在哪些地方进行Joinpoint的织入。
PointCut的表述方式有哪些: 正则表达式(普遍用法)、直接指定Joinpoint所在方法名称、使用特定的PointCut表达语言。
Advice: 代表将会织入到Joinpoint的横切逻辑。
Advice在Joinpoint位置执行时机的差异或者完成功能的不同,可以分为多种具体形式:Before Advice、After Adivce、After returning Advice、After throwing Advice、After Finally Advice、Around Advice、Introduction。
- Aspect: 代表对系统中的横切关注点逻辑进行模块化封装的AOP实体概念
AOP织入器
需要将我们之前定义好的那些横切逻辑织入到原来的业务代码中,就需要用到一个叫织入器
的东西
常见织入器有:
- AspectJ 技术的
ajc
织入器 - JBoss AOP 采用
自定义类加载器
作为织入器来完成织入 - Spring AOP 将
ProxyFactory
作为 织入器来完成织入