java 適配器模式

来源:https://www.cnblogs.com/zy115/p/18137252
-Advertisement-
Play Games

適配器模式(Adapter Pattern) 結構型設計模式,見名知意,就是兩個不相容的介面之間的橋梁。它結合了兩個獨立介面的功能。 主要解決:常常要將一些"現存的對象"放到新的環境中,而新環境要求的介面是現對象不能滿足的。 關鍵代碼:適配器繼承或依賴已有的對象,實現想要的目標介面。 優點: 1、可 ...


適配器模式(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);
    }

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • TypeScript 包含的數據類型如下表: 註意: TypeScript 和 JavaScript 沒有整數類型。 Any 類型 任意值是 TypeScript 針對編程時類型不明確的變數使用的一種數據類型,它常用於以下三種情況。 1、變數的值會動態改變時,比如來自用戶的輸入,任意值類型可以讓這些 ...
  • iOS系統崩潰的捕獲 相信大家在開發iOS程式的時候肯定寫過各種Bug,而其中最為嚴重的Bug就是會導致崩潰的Bug(一般來說妥妥的P1級)。在應用軟體大大小小的各種異常中,崩潰確實是最讓人難以接受的行為。畢竟崩潰意味著用戶將丟失應用程式運行中的所有上下文環境,丟失其所有未保存的數據,會帶給用戶最糟 ...
  • 隨著互聯網技術的迅速發展,用戶對網頁的載入速度和交互體驗有了更高的期待。作為開發者,我們常常需要在伺服器端渲染(SSR)與客戶端渲染(CSR)之間做出選擇。這兩種渲染方式各有特點,適用於不同的場景和需求。今天,就讓我們一起來探索SSR和CSR的世界,幫助你為你的應用選擇最合適的渲染策略。 什麼是渲染 ...
  • 錨點鏈接 <a href="#Cat"></a> 點擊這個鏈接將為跳轉到這個頁面上id為Cat的頁面 利用這個功能,我們可以實現給一個頁面插眼的功能。 比如我們想建一個動物園的網站 <!-- 動物園導航欄--> <header> <ul> <li><a href="cat">Cats</a></li ...
  • 關於微信小程式轉發&保存圖片 已經好多年沒寫博客了,最近使用在用uniapp開發一個移動版管理後臺,記錄下自己踩過的一些坑 微信小程式圖片轉發保存簡單說明 微信小程式圖片轉發保存,依賴小程式的轉發api—— wx.showShareImageMenu(Object object) 通過調用這個api ...
  • 0x01 概述 API 是一些預先定義的函數,提供應用程式與開發人員基於某軟體或硬體訪問一組常式的能力 Web APIs 是 W3C 組織的標準,是 JS 獨有的部分 Web API 是瀏覽器提供的一套操作瀏覽器功能和頁面元素的 API,即 DOM 與 BOM 0x02 DOM (1)簡介 文檔對象 ...
  • 1、首先構造函數為中心 function Person() { } var p = new Person(); console.log('Person::', p) console.log(p.constructor Person) 列印如下: 可以看出構造函數通過new得到實例,實例可以通過【co ...
  • 今天我為大家帶來新的作品,iOS17桌面組件神器(Scriptable)原創腳本,精美作品分享!喜歡的話就點關註吧!更多腳本正在路上... * script : ONE-Progress.js * version : 1.0.0 * author : Nicolas-kings * date : 2 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...