【小结】动态代理

2019-07-20  本文已影响0人  桌面很乱

在项目运行的时候才创建一个代理对象,对方法进行增强(控制)

方式1:

jdk中Proxy类,前提:实现接口

方式2:

spring中cglib,前提:继承类

动态的在内存中创建一个代理对象

Object Proxy.newProxyInstance(ClassLoader loader, Class[] interfaces, InvocationHandler h)

参数说明:

ClassLoader:代理对象类加载器 一般我们使用的是被代理对象的类加载器
Class[]:代理对象需要实现接口 一般我们使用的是被搭理对象所实现的所有接口

InvocationHandler:执行处理类.在这里面对方法进行加强

invocationHandler中只有一个方法:

Object invoke(Object proxy, Method method, Object[] args)

参数说明:

proxy:代理对象

method:当前执行的方法

args:当前方法执行的时候所需要的参数

返回值:就是当前method对象执行的返回值


例子:QQ类继承Car接口,实现了run方法和stop方法

public class TT {

  public static void main(String[] args) {

    final QQ qq=new QQ();

    //创建代理对象

    Car qqProxy=(Car) Proxy.newProxyInstance(QQ.class.getClassLoader(), new Class[]{Car.class}, new InvocationHandler() {

        @Override

        public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {

            if("run".equals(method.getName())){

                System.out.println("加上电池");
                //这里的obj表示方法的返回值,method.invoke执行一次就代表原来的方法执行了一次
                Object obj = method.invoke(qq, args);

                System.out.println("5秒破百");
                //这里的obj表示方法的返回值,汽车的run方法是打印输出语句,没有返回值,所以obj相当于null。
                return obj;

            }
            //method.invoke执行一次就代表原来的方法执行了一次,并且通过return把这个方法的返回值返回。
            return method.invoke(qq, args);

        }

    });

    qqProxy.run();

    qqProxy.stop();

  }

}
上一篇 下一篇

猜你喜欢

热点阅读