设计模式之代理模式—动态代理(重点是cglib的两大注意事项)

这些什么设计模式啊,什么这样那样的原理啊,网上真的一大堆,自己写来权当笔记,推荐一篇文章:https://cloud.tencent.com/developer/article/1461796 

这里还是重点说两个东西吧,对于使用cglib方式时,要注意以下两个方面(当然无法代理final类就不说了):

1、methodProxy.invokeSuper(o,objects);

 @Override
    public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
        System.out.println("前置方法");
        methodProxy.invokeSuper(o,objects);
        System.out.println("后置对象");
        return null;
    }

 

1.1、对于这个方式,如果形如下图所示,A()中调用B()方法,此时A()与B()都会走增强逻辑,也即,当代理类直接调用A()方法时,当执行B()时,B()方法也会被拦截器拦截走一次增强逻辑;

2、methodProxy.invoke(this.target,objects);

2.1、对于methodProxy.invoke(),如果第一个参数是o,也就是代理对像,那么就会出现OOM内存溢出现象,这是由于当在程序中,当生成了代理类去调用具体类(被代理类)的方法时,会先去走拦截器,然后跑代理类增强后的方法,此时,在增强方法中,利用代理对象又去调用具体类的方法,又会再次去走拦截器跑代理类增强后的方法,这样就会出现无限循环的情况导致OOM;

2.2、对于对于methodProxy.invoke(),如果第一个参数是this.object,那么当程序中生成代理类时,去调用A()方法时,依旧先去走增强逻辑,但是此时,如果形如下图所示情况,A()方法内部调用B()方法,B()方法就不会执行增强逻辑(这和AOP的行为相似,只增强直接调用的方法,不会增强调用方法内部继续调用的其他方法)

总结:

1、对于A()方法中会内部调用B()方法这种形式:对于使用methodProxy.invokeSuper(o,objects),那么A()与B()都会被拦截走增强逻辑;

2、对于A()方法中会内部调用B()方法这种形式:对于使用methodProxy.invoke(this.object,objects),那么A()会被拦截走增强逻辑,但是内部调用的B()方法不会被拦截;

3、对于使用methodProxy.invoke(o,objects),则会出现OOM内存溢出;

4、对于public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {}方法中的第二个参数method 使用 method.invoke(this.object,objects)与使用methodProxy.invoke(this.object,objects)是相同的效果;

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值