前几天MK开始弄JAVA,在群里讨论AOP的相关话题,我在搜索相关话题时看到wu_yanan2003兄06年写的一篇关于hookapi的文章《delphi下AOP技术( hookapi full source) 》。对于其中关于AOP的观点,我觉得有必要与他讨论一下。
首先是思想与实现技术的区别。
我在《用Delphi实现动态代理(2):设计说明 》一文里已经说过,AOP本身是一种思想,或者如维基百科定义 所 说,是一种程序设计范型。而像AspectJ、DynamicProxy、Mixin之类的则是实现AOP的具体技术。hook当然也可以用来作为实现 AOP的技术之一。但不能因此说哪个“是”AOP。就像我们不能说JAVA是OOP一样,JAVA只是一种OOPL,可以用来实现OOP,但就算是非 OOPL的C语言,也可以用来实现OOP。
其次是如何横切的问题。
不可否认,hook的功能很强大,可以实现函数级的精确切入,但是用它来实现AOP却未必是好技术。问题就在于它太过于底层,对切入动作的抽象不够,反而增加了程序员的工作量,达不到AOP横切所要达到的目标——为应用提供统一的横切处理实现。