静态代理与动态代理

最近在看Spring,其AOP的实现 涉及到代理模式:分为静态模式和动态模式,特此记之。代码全部用Spring实现:

一、GOF 的代理模式(Proxy Pattern),静态代理
 
一个客户(Client)不想或者不能够直接引用一个对象(RealSubject),而代理对象(Proxy)给此对象提供一个代理,并由代理对象控制对原对象的引用(realSubject.Request()),在客户端和目标对象之间起到中介的作用;
应用:
Spring的AOP
 如用户Client希望加入切面,如“日志”功能,又不希望修改原程序,那么为每一个对象建立一个通用的Proxy,将切面功能加入Proxy
.Net 的 XML Web Services,Client端都是通过本地Proxy class来转发对Remote Objects or Services的请求,和获取来自Remote的响应
例程:
IHello.java (subject)
public interface IHello {
 public void hello();
}
Hello.java (RealSubject)
public class Hello implements IHello {
 public void hello() {
  System.out.println("say hello");

 }
HelloProxy.java (Proxy)
public class HelloProxy implements IHello{
 private IHello helloOject;
 public HelloProxy(IHello helloOject) {
  this.helloOject = helloOject;
 }
 public void hello() {
  System.out.println("began before method");
  this.helloOject.hello();
  System.out.println("began after method");  
 }
}
MyMain.java (client)
public class MyMain {
 public static void main(String[] args) {
  BeanFactory factory=new FileSystemXmlApplicationContext("mybean.xml");
  IHello hello=(IHello)factory.getBean("helloProxy");
  hello.hello();
 }
}
二、Java动态代理与静态代理的不足
 
例程:
MyHandler.java (RealHandler)
public class MyHandler implements InvocationHandler {
 private Object delegate;
 
 public void setDelegate(Object delegate) {
  this.delegate = delegate;
 }
 public Object bind(){
  return Proxy.newProxyInstance(delegate.getClass().getClassLoader(),
    delegate.getClass().getInterfaces(),this);
 }
 public Object invoke(Object proxy, Method method, Object[] args)
   throws Throwable {
  System.out.println("began before method");
  Object result=method.invoke(delegate, args);//注意第一个参数是被代理对象delegate!
  System.out.println("began after method"); 
  return result;
 }
}
MyMain.java (client)
 public static void main(String[] args) {
  BeanFactory factory=new FileSystemXmlApplicationContext("mybean.xml");
  MyHandler handler=(MyHandler)factory.getBean("helloDProxy");
  IHello hello=(IHello)handler.bind();
  hello.hello();
 }

问题:静态代理的问题是Proxy不通用和被代理对象耦合太紧,一个代理只能代表一个对象。动态代理则可以代表任何对象
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值