一、需求:在程序执行期间追踪正在发生的活动
(1)接口
data:image/s3,"s3://crabby-images/799b7/799b75a64479e2e02d62c24db3e01f06db54b5b9" alt=""
(2)实现该接口的方法
data:image/s3,"s3://crabby-images/1fe1f/1fe1f5dde84344ab9a9ffd30d3605521f30e0860" alt=""
(3)调用该方法,执行结果
data:image/s3,"s3://crabby-images/bd05c/bd05c74e6b578120fd60dfba8eb2f636deb625d2" alt=""
二、问题
代码混乱:越来越多的非业务需求(日志和验证等)加入后, 原有的业务方法急剧膨胀. 每个方法在处理核心逻辑的同时还必须兼顾其他多个关注点.
代码分散: 以日志需求为例, 只是为了满足这个单一需求, 就不得不在多个模块(方法)里多次重复相同的日志代码. 如果日志需求发生变化, 必须修改所有模块.
三、使用动态代理解决上述问题
代理设计模式的原理: 使用一个代理将对象包装起来, 然后用该代理对象取代原始对象. 任何对原始对象的调用都要通过代理. 代理对象决定是否以及何时将方法调用转到原始对象上.
data:image/s3,"s3://crabby-images/c16bc/c16bc36eba8c0975772c4772d3930f7698a51992" alt=""
data:image/s3,"s3://crabby-images/ffed5/ffed56c50e707e5426cc5cf15ad0a01e00371b57" alt=""
data:image/s3,"s3://crabby-images/9f880/9f880e77fd26f984c59f6eed228038d6a5744833" alt=""
网友评论