隨筆-31  評論-2  文章-0  trackbacks-0
            Proxy代理模式是一種結構型設計模式,主要解決的問題是:在直接訪問對象時帶來的問題,比如說:要訪問的對象在遠程的機器上。在面向對象系統中,有些對象由于某些原因(比如對象創建開銷很大,或者某些操作需要安全控制,或者需要進程外的訪問),直接訪問會給使用者或者系統結構帶來很多麻煩,我們可以在訪問此對象時加上一個對此對象的訪問層。如下圖:
             



                 比如說C和A不在一個服務器上,A要頻繁的調用C,我們可以在A上做一個代理類Proxy,把訪問C的工作交給Proxy,這樣對于A來說,就好像在直接訪問C的對象。在對A的開發中我們可以把注意力完全放在業務的實現上。

                 GoF《設計模式》中說道:為其他對象提供一種代理以控制這個對象的訪問。

                 Proxy模式的結構:
             



                 下面通過一個場景來看看Proxy的實現,我們要使用代理類型ProxyClass的對象調用遠程機器上的一個類型LongDistanceClass的對象。

              首先我們先模擬一個遠程的類型:為了保持對被代理對象使用的透明性,我們使代理類型和被代理類型同時繼承同一個接口IProxy

              接口實現:

              interface IProxy

              {

                  string Function1();

                  string Function2();

              }

              遠程對象實現:

              /// <summary>

              /// 模擬的遠程對象

              /// </summary>

              public class LongDistanceClass:IProxy

              {

                  #region IProxy 成員

                  public string Function1()

                  {

                      //do someting

                      return "LongDistanceClass.Function1";

                  }

                  public string Function2()

                  {

                      //do someting

                      return "LongDistanceClass.Function2";

                  }

                  #endregion

              }

              接下來就要實現代理類型,使用代理對象訪問模擬的遠程對象,代理類型實現如下:

              public class ProxyClass:IProxy

              {

                  #region IProxy 成員

                  public string Function1()

                  {

                      //to access LongDistanceClass.Function1

                      LongDistanceClass obj = new LongDistanceClass();

                      return obj.Function1();

                  }

                  public string Function2()

                  {

                      //to access LongDistanceClass.Function2

                      LongDistanceClass obj = new LongDistanceClass();

                      return obj.Function2();

                  }

                  #endregion

              }

           

              最后實現客戶端代碼:

              class Class1

              {

                  [STAThread]

                  static void Main(string[] args)

                  {

                      IProxy pro = new ProxyClass();

                      Console.WriteLine(pro.Function1());

                      Console.WriteLine(pro.Function2());

                      Console.Read();

                  }

              }

              運行結果如下:

              LongDistanceClass.Function1

          LongDistanceClass.Function2

                 Proxy模式的要點:

                 1、“增加一層間接層”是軟件系統中對許多負責問題的一種常見解決方法。在面向對象系統中,直接使用某些對象會帶來很多問題,作為間接層的proxy對象便是解決這一問題的常用手段。

                 在我們日常的工作中也常常用到代理模式,比如對于三層結構或者N- tiers結構中DAL數據訪問層,它把對數據庫的訪問進行封裝。BLL業務層的開發者只是調用DAL中的方法來獲得數據。

                 在比如前一段時間看了看AOP和Remoting方面的資料,對于跨越應用程序域的訪問,要為客戶應用程序提供一個TransparentProxy(透明代理),客戶程序實際上是通過訪問這個代理來訪問實際的類型對象。

          2、具體proxy設計模式的實現方法、實現粒度都相差很大,有些可能對單個對象作細粒度的控制,有些可能對組件模塊提供抽象代理層,在架構層次對對象作proxy。

          3、proxy并不一定要求保持接口的一致性,只要能夠實現間接控制,有時候損及一些透明性是可以接受的。例如上面的那個例子,代理類型ProxyClass和被代理類型LongDistanceClass可以不用繼承自同一個接口,正像GoF《設計模式》中說的:為其他對象提供一種代理以控制這個對象的訪問。代理類型從某種角度上講也可以起到控制被代理類型的訪問的作用。
          posted on 2009-08-04 14:44 xiaoxinchen 閱讀(151) 評論(0)  編輯  收藏

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


          網站導航:
          博客園   IT新聞   Chat2DB   C++博客   博問  
           
          主站蜘蛛池模板: 霸州市| 大安市| 通州市| 鹿邑县| 原阳县| 合川市| 湘西| 江门市| 庆安县| 潜山县| 乡宁县| 韶关市| 肃宁县| 丘北县| 华池县| 武乡县| 湟中县| 靖宇县| 丰镇市| 突泉县| 抚宁县| 荃湾区| 巴青县| 丰都县| 松阳县| 环江| 钟祥市| 通州市| 昌宁县| 英山县| 额敏县| 永修县| 增城市| 阜新市| 筠连县| 贵德县| 子洲县| 镇赉县| 巴彦淖尔市| 犍为县| 马尔康县|