在不少 Java 体系里,动态代理是一把非常好用的“手术刀”:你不去碰原来的业务代码,却能在方法调用的入口和出口塞进日志、鉴权、性能埋点、灰度开关、缓存等横切逻辑。对长期和 SAP 打交道的 ABAP 开发者来说,这种感觉并不陌生——我们早就习惯了 enhancement、BAdI、隐式增强点、user exit、implicit / explicit enhancement 的那套“前置 / 后置”增强思路。
CGLIB 把这种“在运行时生成一个代理对象”的能力做到了极致:它不是靠接口,而是靠生成目标类的子类,并在子类里覆盖方法,把调用转发到拦截器里,再决定要不要回调原方法。官方仓库对它的定位也非常直接:这是一个字节码生成库,用于生成动态代理对象并拦截方法或字段访问,常见于 AOP、测试、数据访问框架等场景。(GitHub)
更有意思的是:这套思想并不只属于 Java。只要语言具备一定的运行期元编程能力(或者能在运行时拼装并加载代码),就能“借鉴”出一套同等味道的实现。下面这篇文章就聚焦在一个很硬核、也很 ABAP 的目标:在 ABAP 里实现类似 CGLIB 的动态代理,让method pre-exit / post-exit这种增强可以做到非侵入,并且不把新类永久写进仓库。