java 介面卡模式

zy平平仄仄發表於2024-04-16

介面卡模式(Adapter Pattern)

  結構型設計模式,見名知意,就是兩個不相容的介面之間的橋樑。它結合了兩個獨立介面的功能。

  主要解決:常常要將一些"現存的物件"放到新的環境中,而新環境要求的介面是現物件不能滿足的。

  關鍵程式碼:介面卡繼承或依賴已有的物件,實現想要的目標介面。

  優點: 1、可以讓任何兩個沒有關聯的類一起執行。 2、提高了類的複用。 3、增加了類的透明度。 4、靈活性好。

  缺點: 1、過多地使用介面卡,會讓系統非常零亂,不易整體進行把握。 2.由於 JAVA 至多繼承一個類,所以至多隻能適配一個適配者類,而且目標類必須是抽象類。

  組成:

    1.目標(target)
    2.源頭(source)
    3.介面卡 (adapter)

  注意事項:介面卡不是在詳細設計時新增的,而是解決正在服役的專案的問題。

======================================================== 以上八股文 來源 菜鳥================================================================================================

舉個小例子:

  某個程式,最初設計是mysql 資料庫, 分頁的 關鍵字是 limit, 程式被賣了兩家公司,一家公司是 db2資料庫, 一家公司是 Oracle資料庫 , 程式的sql 語句 需要相容 兩家資料庫的 分頁 關鍵字,且不能丟掉原有的, 這個時候就可以使用介面卡模式, 適配其他兩種資料庫的關鍵字 。

程式碼如下:

  

/**
 * 基礎分頁介面
 */
public interface BasePage {
    public void page(String urlType,String sql);

}

/**
 * 其他分頁介面(Oracle,DB2)
 */
public interface OtherPage {
    void oraclePage(String sql);
    void db2Page(String sql);
}

/**
 * Oracle 的實現
 */
public class OraclePage implements OtherPage{
    @Override
    public void oraclePage(String sql) {
        String oracleSql = sql.replace("limit","ROW_NUMBER");
        System.out.println("oracle: " + oracleSql);
    }
    @Override
    public void db2Page(String sql) {}
}

/**
 * db2 的實現
 */
public class DB2Page implements OtherPage{
    @Override
    public void oraclePage(String sql) {}

    @Override
    public void db2Page(String sql) {
        String db2Sql  = sql.replace("limit","RowNumber");//為了區分Oracle的ROW_NUMBER 改為駝峰式
        System.out.println("DB2 : " + db2Sql);
    }
}

/**
 * 介面卡
 */
public class PageAdapter implements BasePage{
    OtherPage otherPage;
    @Override
    public void page(String urlType, String sql) {
        if(urlType.contains("db2")){
            otherPage = new DB2Page();
            otherPage.db2Page(sql);
        }else if(urlType.contains("oracle")){
            otherPage = new OraclePage();
            otherPage.oraclePage(sql);
        }
    }
}

/**
 * 預設查詢分頁類
 */
public class SelectPage implements BasePage {
    PageAdapter pageAdapter;
    @Override
    public void page(String urlType, String sql) {
        if (urlType.contains("mysql")) {
            System.out.println("mysql : " + sql);
        } else if (urlType.contains("db2") || urlType.contains("oracle")) {
            pageAdapter = new PageAdapter();
            pageAdapter.page(urlType, sql);
        } else {
            System.err.println("不支援的資料庫" + urlType);
        }
    }
}
//測試執行
    public static void main(String[] args) {
        String sql = " select * from xxxx  limit xx; ";
        SelectPage selectPage = new SelectPage();
        selectPage.page("jdbc:mysql://xxxxxxxxxxx",sql);
        selectPage.page("jdbc:db2://xxxxxxxxxxx",sql);
        selectPage.page("jdbc:oracle://xxxxxxxxxxx",sql);
        selectPage.page("jdbc:sqlserver://xxxxxxxxxxx",sql);
    }

結果:

==========================================收工=================================================================================

補充一個 程式碼, 特定業務場景會用到, 需要琢磨一下,Abstract類寫固定程式碼, 各個子類 寫 特殊程式碼

/**
 * 基礎分頁介面
 */
public interface BasePage {
    public void page(String urlType,String sql);

}

/**
 * 其他分頁介面(Oracle,DB2)
 */
public interface OtherPage {
    void oraclePage(String sql);
    void db2Page(String sql);
}

/**
 * 抽象類
 */
public abstract class AbstractOtherPageClass implements OtherPage {
    @Override
    public void oraclePage(String sql) {
        String oracleSql = sql.replace("limit","ROW_NUMBER");
        System.out.println("oracle: " + oracleSql);
    }
    @Override
    public void db2Page(String sql) {
        String db2Sql  = sql.replace("limit","RowNumber");//為了區分Oracle的ROW_NUMBER 改為駝峰式
        System.out.println("DB2 : " + db2Sql);
    }
}

/**
 * OraclePage 繼承抽象類,不需要實現所有介面
 */
public class OraclePage extends AbstractOtherPageClass{
    @Override
    public void oraclePage(String sql) {
        super.oraclePage(sql);
        //子類特有方法
    }
}

/**
 * db2 繼承抽象類,不需要實現所有介面
 */
public class DB2Page extends AbstractOtherPageClass{
    @Override
    public void db2Page(String sql) {
        super.db2Page(sql);
        //子類特有方法
    }
}

/**
 * 介面卡 繼承 抽象類,實現 基類。也可以new 子類物件
 */
public class PageAdapter extends AbstractOtherPageClass implements BasePage {

//    OtherPage otherPage;

    @Override
    public void page(String urlType, String sql) {
        if(urlType.contains("db2")){
            super.db2Page(sql);
//            otherPage = new DB2Page();
//            otherPage.db2Page(sql);
        }else if(urlType.contains("oracle")){
            super.oraclePage(sql);
//            otherPage = new OraclePage();
//            otherPage.oraclePage(sql);
        }
    }
}

//測試main方法
    public static void main(String[] args) {
        String sql = " select * from xxxx  limit xx; ";
        SelectPage selectPage = new SelectPage();
        selectPage.page("jdbc:mysql://xxxxxxxxxxx",sql);
        selectPage.page("jdbc:db2://xxxxxxxxxxx",sql);
        selectPage.page("jdbc:oracle://xxxxxxxxxxx",sql);
        selectPage.page("jdbc:sqlserver://xxxxxxxxxxx",sql);
    }

  

相關文章