java 設計模式之適配器模式

  1. 適配器模式是各種模式的起源
  2. 這裏寫圖片描述
  3. 平時我們會經常碰到這樣的情況,有了兩個現成的類,它們之間沒有什麼聯繫,但是我們現在既想用其中一個類的方法,同時也想用另外一個類的方法。有一個解決方法是,修改它們各自的接口,但是這是我們最不願意看到的。這個時候Adapter模式就會派上用場了。
  4. 適配器模式將某個類的接口轉換成客戶端期望的另一個接口表示,目的是消除由於接口不匹配所造成
    的類的兼容性問題。主要分爲三類:類的適配器模式、對象的適配器模式、接口的適配器模式
    1. 類的適配器

這裏寫圖片描述

核心思想就是:有一個 Source 類,擁有一個方法,待適配,目標接口是 Targetable,通過 Adapter 類,
將 Source 的功能擴展到 Targetable 裏,看代碼:

待適配的類
public class Source {

    public void methon1(){
        System.out.println("this is source metho1");
    }
}

接口:

public interface Targetable {

    /**
     * 於原生類方法相同
     */
    public void methon1();
    /**
     * 新類的方法
     */
    public void methon2();
}

適配開始:

public class Adapter extends Source implements Targetable{

    @Override
    public void methon2() {
        System.out.println("this is targetable methon");

    }

}

測試:

public class AdapterTest {
    //這樣 Targetable 接口的實現類就具有了 Source 類的功能。
    public static void main(String[] args) {
        Targetable t  =new  Adapter();
        t.methon1();
        t.methon2();
    }
}

this is source metho1
this is targetable methon

這樣 Targetable 接口的實現類就具有了 Source 類的功能。

2、對象的適配器
基本思路和類的適配器模式相同,只是將 Adapter 類作修改,這次不繼承 Source 類,而是持有 Source
類的實例,以達到解決兼容性的問題。看圖:

這裏寫圖片描述

public class Wrapper implements Targetable{

    private Source source;

    public Wrapper(Source source) {
        super();
        this.source = source;
    }

    @Override
    public void methon1() {
        source.methon1();

    }

    @Override
    public void methon2() {
        System.out.println("this is the targetable method   ");

    }

}

測試:


/**
 *  對象的適配器
 * @author Administrator
 *
 */
public class WrapperTest {

    public static void main(String[] args) {

        Wrapper w = new Wrapper(new Source());

        w.methon1();
        w.methon2();
    }
}
this is source metho1
this is the targetable method   
輸出與第一種一樣,只是適配的方法不同而已。

接口的適配器模式

第三種適配器模式是接口的適配器模式,接口的適配器是這樣的:有時我們寫的一個接口中有多個抽象
方法,當我們寫該接口的實現類時,必須實現該接口的所有方法,這明顯有時比較浪費,因爲並不是所
有的方法都是我們需要的,有時只需要某一些,此處爲了解決這個問題,我們引入了接口的適配器模式,
藉助於一個抽象類,該抽象類實現了該接口,實現了所有的方法,而我們不和原始的接口打交道,只和
該抽象類取得聯繫,所以我們寫一個類,繼承該抽象類,重寫我們需要的方法就行。看一下類圖:
這裏寫圖片描述

/**
 * 這個很好理解,在實際開發中,我們也常會遇到這種接口中定義了太多的方法,以致於有時我們在一些
實現類中並不是都需要。看代碼:
 * @author Administrator
 *
 */
public interface Sourceable {

    public void method1();

    public void method2();

}
public class SourceSub1 extends Wrapper2{

    public void  method1(){
        System.out.println("the sources interface's first sub1");
    }
    }

    public class SourecSub2 extends Wrapper2{

    public void method2(){

        System.out.println("the sources interface's first sub2");
    }
}

適配開始:

public abstract class Wrapper2 implements Sourceable{

    public void method1(){};

    public void method2(){};
}

測試:

public class SourceTest {


    public static void main(String[] args) {

        Sourceable sub1 = new SourceSub1();
        Sourceable sub2 = new SourecSub2();
        sub1.method1();
        sub1.method2();
        sub2.method1();
        sub2.method2();
    }
}
the sources interface's first sub1
the sources interface's first sub2

測試輸出:
the sourceable interface’s first Sub1!
the sourceable interface’s second Sub2!
達到了我們的效果!
講了這麼多,總結一下三種適配器模式的應用場景:
類的適配器模式:當希望將一個類轉換成滿足另一個新接口的類時,可以使用類的適配器模式,創建一
個新類,繼承原有的類,實現新的接口即可。
對象的適配器模式:當希望將一個對象轉換成滿足另一個新接口的對象時,可以創建一個 Wrapper 類,
持有原類的一個實例,在 Wrapper 類的方法中,調用實例的方法就行。
接口的適配器模式:當不希望實現一個接口中所有的方法時,可以創建一個抽象類 Wrapper,實現所
有方法,我們寫別的類的時候,繼承抽象類即可。

適配器模式的三個特點:
1 適配器對象實現原有接口
2 適配器對象組合一個實現新接口的對象(這個對象也可以不實現一個接口,只是一個單純的對象)
3 對適配器原有接口方法的調用被委託給新接口的實例的特定方法

  • 說句實話.我現在看幾個設計模式.代碼上相對來說不是那麼複雜, 但是在工作中真正的用到確實不是那麼容易.所以小夥伴們一定要堅持看完.多寫多練 慢慢的在你寫代碼的時候.就會形成一種意識.讓你覺得,還有更好的方式可以實現它.

發佈了35 篇原創文章 · 獲贊 13 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章