这些什么设计模式啊,什么这样那样的原理啊,网上真的一大堆,自己写来权当笔记,推荐一篇文章: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)是相同的效果;