Hook与AOP

本文探讨了Hook和AOP之间的区别,强调AOP是一种编程范型,而Hook是实现AOP的一种技术手段。文章指出,虽然Hook能够实现精细的函数切入,但其底层性质增加了程序员的工作量,不符合AOP的横切目标。相比之下,DynamicProxy等技术提供了更便捷的横切关注点实现。总结了Hook需要逐个函数切入,而DynamicProxy能一次性处理对象的所有函数,实现了更高层次的抽象和统一处理。
摘要由CSDN通过智能技术生成

前几天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横切所要达到的目标——为应用提供统一的横切处理实现。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值