SpringAOP的两种代理及其实现

  • 静态代理

传统的代理模式,其UML图:

        采用这种方法,在Subject接口中有多少方法,Proxy中就要有多少方法,而这些方法中只是调用了RealSubject中的方法,可以说是很没有必要,显得冗余。所以在SpringAOP中使用的是动态代理,而动态代理又分为两类,1.jdk代理,2.Cglib代理。

  • 动态代理

1.jdk代理(只能基于接口):

接口:

RealSubject:

Proxy:

        可以看到代理类没有再实现Subject接口了,而是实现了InvocationHandler接口,该接口内只有一个invoke方法,是用来实现利用反射调用RealSubject中的对应方法的,而不用再把Subject接口中的方法都实现一遍了。

Client:

       使用Proxy类的newProxyInstance方法得到代理对象,该方法的三个参数分别为:1.声明代理类的类加载器,也就是要使用代理对象的类的类加载器;2.代理类要实现的所有接口;3.对应的接口中的方法要分发去的目标Handler,也就是代理对象。因为该代理实现是使用反射实现的, 所以要获得Class对象。首先会调用getProxyClass()方法从缓存中查找,没有的话会交给ProxyClassFactory创建,但是它又不会直接创建而是委托给ProxyGenertor生成Class。

2.Cglib代理

        Subject接口和RealSubject的实现不变,主要是代理类的实现和客户端的调用实现上有所不同。Proxy:

代理类继承了MethodInteceptor接口,该接口又继承了Callback接口,拦截被代理的方法的调用,并且返回执行的结果。MethodProxy类在被拦截方法也就是被代理的方法被调用时会把RealSubject注册到代理对象中,然后决定是否执行注册对象的方法或者是另外一个相同类不同对象的该方法。

Client:

superClass即MethodProxy中由Enhancer创建的要注册的对象所要继承的类。

另外要注意的是,AOP拦截不了static,final,private方法因为AOP的实现是jdk代理和Cglib代理,这两种代理的实现是基于接口和基于继承的,而接口中的方法只能是public的,类中的private不能被继承,而final方法,static方法不能被重写,所以AOP拦截不了这些方法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卷福。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值