31.4使用AOP技术输出Log
31.4.1 AOP简介
程序要完成一件事情,一定会有一些步骤,1、2、3、4这样。这里分解出来的每一个步骤可以认为是一个切面。针对每一个切面的间隙,塞一些代码进去,在程序正常进行1、2、3、4步的间隙可以跑到塞进去的代码,那么写这些代码就是面向切面编程(AOP,Aspect-Oriented Programming)。
在开发过程中,有些功能是横跨并嵌入众多模块里的,比如打印日志,比如统计某个模块中某些函数的执行时间等。这些功能在各个模块里分散得很厉害,可能到处都能见到。
AOP的目标是把这些功能集中起来,放到一个统一的地方来控制和管理。如果说,OOP如果是把问题划分到单个模块的话,那么AOP就是把涉及到众多模块的某一类问题进行统一管理。
AOP就是通过预编译方式或运行期动态代理实现程序功能的统一维护的一种技术。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。
AOP技术一些常用的术语如下:
Cross-cuttingconcerns: 尽管面向对象模型中大多数类会实现单一特定的功能,但通常也会开放一些通用的附属功能给其他类。例如,可能需要在数据访问层中的类中添加日志,以及UI层中的类,当一个线程进入或者退出一个方法时添加日志。尽管每个类都有一个区别于其他类的主要功能,