<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    tbwshc

    Java動態代理設計模式

     所謂動態代理類是在運行時生成的class,在生成它時,你必須提供一組interface給它,則動態代理類就宣稱它實現了這些interface。當然,動態代理類就充當一個代理,你不要企圖它會幫你干實質性的工作,在生成它的實例時你必須提供一個handler,由它接管實際的工作。
      下面通過實例來說明:
      Subject.java 抽象借口:聲明代理對象和真實對象的共同接口
      [java]
      public interface Subject {
      public void doSomething();
      }
      public interface Subject {
      public void doSomething();
      }
      RealSubject.java 真實被tb代理對象
      [java]
      public class RealSubject implements Subject {
      @Override
      public void doSomething() {
      System.out.println("RealSubject.doSomething");
      }
      }
      public class RealSubject implements Subject {
      @Override
      public void doSomething() {
      System.out.println("RealSubject.doSomething");
      }
      }

      DynamicProxy.java 代理對象
      [java]
      import java.lang.reflect.InvocationHandler;
      import java.lang.reflect.Method;
      public class DynamicProxy implements InvocationHandler {
      private Object object;
      public DynamicProxy(Object object) {
      this.object = object;
      }
      @Override
      public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {
      System.out.println("Before Invoke ! method : " + method);
      //我們可以再代理方法調用前后添加功能
      Object result = method.invoke(object, args);
      System.out.println("object : " + object + " result : " + result + " args : " + args);
      System.out.println("After Invoke !");
      return result;
      }
      }
      import java.lang.reflect.InvocationHandler;
      import java.lang.reflect.Method;
      public class DynamicProxy implements InvocationHandler {
      private Object object;
      public DynamicProxy(Object object) {
      this.object = object;
      }
      @Override
      public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {
      System.out.println("Before Invoke ! method : " + method);
      //我們可以再代理方法調用前后添加功能
      Object result = method.invoke(object, args);
      System.out.println("object : " + object + " result : " + result + " args : " + args);
      System.out.println("After Invoke !");
      return result;
      }
      }
      Client.java 測試
      [java]
      import java.lang.reflect.InvocationHandler;
      import java.lang.reflect.Proxy;
      public class Client {
      public static void main(String[] args) throws Exception {
      //創建目標對象,也就是被代理對象
      RealSubject realSubject = new RealSubject();
      //將目標對象交給代理
      InvocationHandler handler = new DynamicProxy(realSubject);
      // Class proxyClass = Proxy.getProxyClass(Subject.class.getClassLoader()
      // , new Class[]{Subject.class});
      // Subject subject = (Subject)proxyClass.getConstructor(new Class[]{InvocationHandler.class})
      // .newInstance(new Object[]{handler});
      //返回代理對象,相當于上面兩句
      Subject subject = (Subject) Proxy.newProxyInstance(handler.getClass().getClassLoader(),
      realSubject.getClass().getInterfaces(),
      handler);
      //叫代理對象去doSomething(),其實在代理對象中的doSomething()中還是會
      //用handler來調用invoke(proxy, method, args) 參數proxy為調用者subject(this),
      //method為doSomething(),tb參數為方法要傳入的參數,這里沒有
      subject.doSomething();
      }
      }
      import java.lang.reflect.InvocationHandler;
      import java.lang.reflect.Proxy;
      public class Client {
      public static void main(String[] args) throws Exception {
      //創建目標對象,也就是被代理對象
      RealSubject realSubject = new RealSubject();
      //將目標對象交給代理
      InvocationHandler handler = new DynamicProxy(realSubject);
      // Class proxyClass = Proxy.getProxyClass(Subject.class.getClassLoader()
      // , new Class[]{Subject.class});
      // Subject subject = (Subject)proxyClass.getConstructor(new Class[]{InvocationHandler.class})
      // .newInstance(new Object[]{handler});
      //返回代理對象,相當于上面兩句
      Subject subject = (Subject) Proxy.newProxyInstance(handler.getClass().getClassLoader(),
      realSubject.getClass().getInterfaces(),
      handler);
      //叫代理對象去doSomething(),其實在代理對象中的doSomething()中還是會
      //用handler來調用invoke(proxy, method, args) 參數proxy為調用者subject(this),
      //method為doSomething(),參數為方法要傳入的參數,這里沒有
      subject.doSomething();
      }
      }
      打印結果:
      Before Invoke ! method : public abstract void Subject.doSomething()
      RealSubject.doSomething
      object : RealSubject@ec6b00 result : null args : null
      After Invoke !
      注意:
      Java動態代理涉及到的兩個類:
      InvocationHandler:該接口中僅定義了一個Object : invoke(Object proxy, Method method, Object[] args);參數proxy指代理類,method表示被代理的方法,args為method中的參數數組,返回值Object為代理實例的方法調用返回的值。這個抽象方法在代理類中動態實現。
      Proxy:所有動態代理類的父類,提供用于創建動態代理類和實例的靜態方法。

    posted on 2013-09-10 17:08 chen11-1 閱讀(273) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 一个人看的www在线观看免费| 日本免费xxxx| 中文无码成人免费视频在线观看| 最近中文字幕mv免费高清在线 | 成人免费a级毛片| 久久精品国产亚洲Aⅴ香蕉| 亚洲精品资源在线| 免费一级全黄少妇性色生活片 | 无码AV片在线观看免费| 国产免费看插插插视频| 久久国产亚洲精品无码| 特级毛片aaaa级毛片免费| 国产精品爱啪在线线免费观看| 亚洲精品国产精品乱码不卞| 亚洲综合激情六月婷婷在线观看| 最近中文字幕免费完整| 亚洲喷奶水中文字幕电影| 成人影片一区免费观看| 亚洲av无码国产精品夜色午夜| 一进一出60分钟免费视频| 大陆一级毛片免费视频观看i| 老色鬼久久亚洲AV综合| 免费黄色福利视频| 亚洲第一综合天堂另类专 | 亚洲日本中文字幕区| 七次郎成人免费线路视频| 亚洲AV无码一区二区乱子伦| 88av免费观看| 亚洲欧美日韩中文无线码| 午夜性色一区二区三区免费不卡视频 | 久久精品国产亚洲av品善| 免费精品国产日韩热久久| 亚洲精品精华液一区二区| 亚洲综合在线另类色区奇米| 一区二区三区在线观看免费| 亚洲精品国产品国语在线| 精品熟女少妇aⅴ免费久久| 国产亚洲日韩在线三区| 天天影视色香欲综合免费| 久久亚洲AV成人无码国产电影| 香蕉高清免费永久在线视频|