黑马程序员技术交流社区

标题: 代理模式小结 [打印本页]

作者: 于世德    时间: 2013-7-25 11:06
标题: 代理模式小结
jvm可以在运行期动态生成出类的字节码,这种动态生成的类一般作为代理类,即动态代理
jvm生成的动态类必须实现一个或多个接口,所以,jvm生成的动态类智能用作具有相同接口的目标类的代理
CGlib库可以动态生成一个类的子类,一个类的子类也可以用作该类的代理
public class JDKProxy implements InvocationHandler {
private Object targetObject;//代理的目标对象
public Object createProxyInstance(Object targetObject){
  this.targetObject = targetObject;
/*
* 第一个参数设置代码使用的类装载器,一般采用跟目标类相同的类装载器
* 第二个参数设置代理类实现的接口
* 第三个参数设置回调对象,当代理对象的方法被调用时,会委派给该参数指定对象的invoke方法
*/
  return Proxy.newProxyInstance(this.targetObject.getClass().getClassLoader(),
    this.targetObject.getClass().getInterfaces(), this);
}
public Object invoke(Object proxy, Method method, Object[] args)
   throws Throwable {
  return method.invoke(this.targetObject, args);//把方法调用委派给目标对象
}
}
当目标类实现了接口,我们可以使用jdk的Proxy来生成代理对象。
public class CGLIBProxy implements MethodInterceptor {
private Object targetObject;//代理的目标对象
public Object createProxyInstance(Object targetObject){
  this.targetObject = targetObject;
  Enhancer enhancer = new Enhancer();//该类用于生成代理对象
  enhancer.setSuperclass(this.targetObject.getClass());//设置父类
  enhancer.setCallback(this);//设置回调用对象为本身
  return enhancer.create();
}
public Object intercept(Object proxy, Method method, Object[] args,
   MethodProxy methodProxy) throws Throwable {
  return methodProxy.invoke(this.targetObject, args);
}
}
CGLIB可以生成目标类的子类,并重写父类非final修饰符的方法。





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2