spring中的设计模式(二)

2.动态代理

JDK的动态代理首先看InvocationHandler接口

public interface InvocationHandler

    extends Callback

{

 

    public abstract Objectinvoke(Object obj, Methodmethod, Object aobj[])

        throws Throwable;

}

这个接口只有一个invoke方法

第一个参数是代理的真实的对象

第二个参数是调用真实对象的方法

第三个是调用方法需要的参数

再看下Proxy类,用的最多的是里面的newProxyInstance方法

public class Proxy

    implements Serializable

{

   public static Object newProxyInstance(ClassLoader loader, Class     interfaces[], InvocationHandler h)

    {

        Class clazz = getProxyClass(loader,interfaces);

        return clazz.getConstructor(new Class[] {

           org.springframework.cglib.proxy.InvocationHandler.class

        }).newInstance(new Object[] {

            h

        });

        RuntimeException e;

        e;

        throw e;

        e;

        throw newCodeGenerationException(e);

    }

}

这个方法的第一个参数是一个ClassLoader对象,定义了由哪个ClassLoader对象来生成代理对象进行加载

第二个参数是一个interfaces的数组,表示我将要给我代理的对象提供什么接口,这样生成代理的对象的时候就可以调用这些接口里面的方法

第三个参数是一个InvocationHandler对象,表示这个动态代理对象调用方法的时候会关联到哪个invocationHandler对象

 

在整个动态代理模式中,每一个代理类都要实现InvocationHandler接口,每一个代理类对象都是一个InvocationHandler对象

这个代理类提供了一个构造方法,参数是Object 类,代表这个代理类对象生成时真正代理的对象

在代理类里面会执行Method对象的invoke方法执行真实对象的方法

 

而在客户端我们会先通过这个代理类得到InvocationHandler对象

然后通过Proxy类的newProxyInstance方法去得到这个真实的对象,然后调用

整个的流程应该是

 

说到动态代理,就不得不提到spring的Aop的实现

Aop的动态代理实现需要四个角色,被代理的类,被代理的接口,织入器,和切面

Proxy.newProxyInstance就是织入器,InvocationHandler是切面,首先织入器利用接口反射机制生成代理类,然后在这个代理类中织入方法,织入的是切面的方法,spring中默认的是动态代理机制试下Aop,因为动态代理机制下代理类必须要实现接口,如果代理类没有实现接口,则采用CGlib机制实现Aop,CGlib机制后续再进行补充

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值