【源码分析设计模式 8】mybatis中的代理模式

六、动态代理

======

1、动态代理特点


  • 代理对象不需要实现接口,但是目标对象要实现接口;

  • 代理对象的生成,是利用JDK的API,动态的在内存中构建代理对象;

  • 动态代理也叫JDK代理或接口代理;

2、使用JDK实现动态代理


jdk实现动态代理必须有实现接口InvocationHandler的处理类,用于执行被代理类的方法。

(1)接口IMovie

package designMode.advance.proxy.dynamic;

public interface IMovie {

void play(String movieName);

void advertising(Boolean isBoforMovie,String txt);

}

(2)实现类Movie

package designMode.advance.proxy.dynamic;

public class Movie implements IMovie {

@Override

public void play(String movieName) {

System.out.println(“您正在观看电影《”+movieName+“》”);

}

@Override

public void advertising(Boolean isBoforMovie, String txt) {

if(isBoforMovie){

System.out.println(“影片马上开始,”+txt);

}else{

System.out.println(“影片正片已经结束,马上彩蛋环节,不要离开哦,”+txt);

}

}

}

(3)代理类MovieProxy

package designMode.advance.proxy.dynamic;

import java.lang.reflect.InvocationHandler;

import java.lang.reflect.Method;

import java.lang.reflect.Proxy;

public class MovieProxy {

private Object target;

public MovieProxy(Object target) {

this.target = target;

}

/*

  • public static Object newProxyInstance(ClassLoader loader,

Class[] interfaces,

InvocationHandler h)

  • 1、ClassLoader loader:指定当前目标对象使用的类加载器,获取加载器的方法;

  • 2、Class[] interfaces:目标对象实现的接口类型,使用泛型方式确认类型;

  • 3、InvocationHandler h:事情处理,执行目标对象的方法时,会触发事情处理器方法,会吧当前

  • */

public Object getProxyInstance(){

return Proxy.newProxyInstance(target.getClass().getClassLoader(),

target.getClass().getInterfaces(),

new InvocationHandler() {

@Override

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

System.out.println(“JDK代理

你可能感兴趣的:(程序员,代理模式,设计模式,mybatis)