我们日常写的代码,可以分为业务逻辑代码和非业务逻辑代码。业务逻辑代码即实际的业务逻辑,比如产品的增删改查。非业务逻辑代码即系统中一些通用功能,这些功能对于系统正常运行非常重要,比如系统的安全日志。
对于业务逻辑代码,我们通常比较容易进行模块化(modularize),各个模块之间的通过接口协议进行交互,保证业务模块间的高内聚和低耦合。
对于所谓的非业务代码,往往散布(scattering)在系统的各个业务模块中,也会跟系统的业务代码交缠(tangling)在一起。对这些代码进行模块化也很有必要,不然,系统开发效率、代码的维护性都会降低。AOP便是解决这个问题的。Aspect就是模块化的非业务代码(crosscutting concern),这些非业务代码通常提供一些通用的系统功能或者服务,比如日志记录、安全拦截、事物开启和提交、缓存等。
Aspect是对这些通用功能的模块化封装,而这些功能的具体实现就是一个个的advice,advice有before、after和throw三种。实现了advice后,还需要定义advice在target object上的执行点或者时机,这就需要定义joint point。一个joint point显然不会对所有的advice都起效,因此就需要定义pointcut来说明一个advice会作用到哪些joint point上。
advice作用到target object的过程叫weave。
在Java领域,AOP通常通过JDK动态代理或者CGLIB代理实现。