<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                # 不兼容結構的協調——適配器模式(四) 9.6 缺省適配器 缺省適配器模式是適配器模式的一種變體,其應用也較為廣泛。缺省適配器模式的定義如下: 缺省適配器模式(Default Adapter Pattern):當不需要實現一個接口所提供的所有方法時,可先設計一個抽象類實現該接口,并為接口中每個方法提供一個默認實現(空方法),那么該抽象類的子類可以選擇性地覆蓋父類的某些方法來實現需求,它適用于不想使用一個接口中的所有方法的情況,又稱為單接口適配器模式。 缺省適配器模式結構如圖9-7所示: ![](http://img.my.csdn.net/uploads/201303/01/1362101177_9180.jpg) 圖9-7 缺省適配器模式結構圖 在缺省適配器模式中,包含如下三個角色: ● ServiceInterface(適配者接口):它是一個接口,通常在該接口中聲明了大量的方法。 ● AbstractServiceClass(缺省適配器類):它是缺省適配器模式的核心類,使用空方法的形式實現了在ServiceInterface接口中聲明的方法。通常將它定義為抽象類,因為對它進行實例化沒有任何意義。 ● ConcreteServiceClass(具體業務類):它是缺省適配器類的子類,在沒有引入適配器之前,它需要實現適配者接口,因此需要實現在適配者接口中定義的所有方法,而對于一些無須使用的方法也不得不提供空實現。在有了缺省適配器之后,可以直接繼承該適配器類,根據需要有選擇性地覆蓋在適配器類中定義的方法。 在JDK類庫的事件處理包java.awt.event中廣泛使用了缺省適配器模式,如WindowAdapter、KeyAdapter、MouseAdapter等。下面我們以處理窗口事件為例來進行說明:在Java語言中,一般我們可以使用兩種方式來實現窗口事件處理類,一種是通過實現WindowListener接口,另一種是通過繼承WindowAdapter適配器類。如果是使用第一種方式,直接實現WindowListener接口,事件處理類需要實現在該接口中定義的七個方法,而對于大部分需求可能只需要實現一兩個方法,其他方法都無須實現,但由于語言特性我們不得不為其他方法也提供一個簡單的實現(通常是空實現),這給使用帶來了麻煩。而使用缺省適配器模式就可以很好地解決這一問題,在JDK中提供了一個適配器類WindowAdapter來實現WindowListener接口,該適配器類為接口中的每一個方法都提供了一個空實現,此時事件處理類可以繼承WindowAdapter類,而無須再為接口中的每個方法都提供實現。如圖9-8所示: ![](http://img.my.csdn.net/uploads/201303/01/1362101198_5374.jpg) 圖9-8 WindowListener和WindowAdapter結構圖 9.7 適配器模式總結 適配器模式將現有接口轉化為客戶類所期望的接口,實現了對現有類的復用,它是一種使用頻率非常高的設計模式,在軟件開發中得以廣泛應用,在Spring等開源框架、驅動程序設計(如JDBC中的數據庫驅動程序)中也使用了適配器模式。 1. 主要優點 無論是對象適配器模式還是類適配器模式都具有如下優點: (1) 將目標類和適配者類解耦,通過引入一個適配器類來重用現有的適配者類,無須修改原有結構。 (2) 增加了類的透明性和復用性,將具體的業務實現過程封裝在適配者類中,對于客戶端類而言是透明的,而且提高了適配者的復用性,同一個適配者類可以在多個不同的系統中復用。 (3) 靈活性和擴展性都非常好,通過使用配置文件,可以很方便地更換適配器,也可以在不修改原有代碼的基礎上增加新的適配器類,完全符合“開閉原則”。 具體來說,類適配器模式還有如下優點: 由于適配器類是適配者類的子類,因此可以在適配器類中置換一些適配者的方法,使得適配器的靈活性更強。 對象適配器模式還有如下優點: (1) 一個對象適配器可以把多個不同的適配者適配到同一個目標; (2) 可以適配一個適配者的子類,由于適配器和適配者之間是關聯關系,根據“里氏代換原則”,適配者的子類也可通過該適配器進行適配。 2. 主要缺點 類適配器模式的缺點如下: (1) 對于Java、C#等不支持多重類繼承的語言,一次最多只能適配一個適配者類,不能同時適配多個適配者; (2) 適配者類不能為最終類,如在Java中不能為final類,C#中不能為sealed類; (3) 在Java、C#等語言中,類適配器模式中的目標抽象類只能為接口,不能為類,其使用有一定的局限性。 對象適配器模式的缺點如下: 與類適配器模式相比,要在適配器中置換適配者類的某些方法比較麻煩。如果一定要置換掉適配者類的一個或多個方法,可以先做一個適配者類的子類,將適配者類的方法置換掉,然后再把適配者類的子類當做真正的適配者進行適配,實現過程較為復雜。 3. 適用場景 在以下情況下可以考慮使用適配器模式: (1) 系統需要使用一些現有的類,而這些類的接口(如方法名)不符合系統的需要,甚至沒有這些類的源代碼。 (2) 想創建一個可以重復使用的類,用于與一些彼此之間沒有太大關聯的一些類,包括一些可能在將來引進的類一起工作。 練習 > Sunny軟件公司OA系統需要提供一個加密模塊,將用戶機密信息(如口令、郵箱等)加密之后再存儲在數據庫中,系統已經定義好了數據庫操作類。為了提高開發效率,現需要重用已有的加密算法,這些算法封裝在一些由第三方提供的類中,有些甚至沒有源代碼。試使用適配器模式設計該加密模塊,實現在不修改現有類的基礎上重用第三方加密方法。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看