適配器模式(Adapter Pattern)
結(jié)構(gòu)型設(shè)計模式,見名知意,就是兩個不兼容的接口之間的橋梁。它結(jié)合了兩個獨立接口的功能。
主要解決:常常要將一些"現(xiàn)存的對象"放到新的環(huán)境中,而新環(huán)境要求的接口是現(xiàn)對象不能滿足的。
關(guān)鍵代碼:適配器繼承或依賴已有的對象,實現(xiàn)想要的目標(biāo)接口。
優(yōu)點: 1、可以讓任何兩個沒有關(guān)聯(lián)的類一起運行。 2、提高了類的復(fù)用。 3、增加了類的透明度。 4、靈活性好。
缺點: 1、過多地使用適配器,會讓系統(tǒng)非常零亂,不易整體進(jìn)行把握。 2.由于 JAVA 至多繼承一個類,所以至多只能適配一個適配者類,而且目標(biāo)類必須是抽象類。
組成:
注意事項:適配器不是在詳細(xì)設(shè)計時添加的,而是解決正在服役的項目的問題。
======================================================== 以上八股文 來源 菜鳥================================================================================================
舉個小例子:
某個程序,最初設(shè)計是mysql 數(shù)據(jù)庫, 分頁的 關(guān)鍵字是 limit, 程序被賣了兩家公司,一家公司是 db2數(shù)據(jù)庫, 一家公司是 Oracle數(shù)據(jù)庫 , 程序的sql 語句 需要兼容 兩家數(shù)據(jù)庫的 分頁 關(guān)鍵字,且不能丟掉原有的, 這個時候就可以使用適配器模式, 適配其他兩種數(shù)據(jù)庫的關(guān)鍵字 。

代碼如下:
/** * 基礎(chǔ)分頁接口 */ public interface BasePage { public void page(String urlType,String sql); } /** * 其他分頁接口(Oracle,DB2) */ public interface OtherPage { void oraclePage(String sql); void db2Page(String sql); } /** * Oracle 的實現(xiàn) */ 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 的實現(xiàn) */ public class DB2Page implements OtherPage{ @Override public void oraclePage(String sql) {} @Override public void db2Page(String sql) { String db2Sql = sql.replace("limit","RowNumber");//為了區(qū)分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); } } } /** * 默認(rèn)查詢分頁類 */ 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("不支持的數(shù)據(jù)庫" + urlType); } } } //測試執(zhí)行 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); }
結(jié)果:

==========================================收工=================================================================================
補充一個 代碼, 特定業(yè)務(wù)場景會用到, 需要琢磨一下,Abstract類寫固定代碼, 各個子類 寫 特殊代碼
/**
* 基礎(chǔ)分頁接口
*/
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");//為了區(qū)分Oracle的ROW_NUMBER 改為駝峰式
System.out.println("DB2 : " + db2Sql);
}
}
/**
* OraclePage 繼承抽象類,不需要實現(xiàn)所有接口
*/
public class OraclePage extends AbstractOtherPageClass{
@Override
public void oraclePage(String sql) {
super.oraclePage(sql);
//子類特有方法
}
}
/**
* db2 繼承抽象類,不需要實現(xiàn)所有接口
*/
public class DB2Page extends AbstractOtherPageClass{
@Override
public void db2Page(String sql) {
super.db2Page(sql);
//子類特有方法
}
}
/**
* 適配器 繼承 抽象類,實現(xiàn) 基類。也可以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);
}
}
}
/**
* 默認(rèn)查詢分頁類
*/
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("不支持的數(shù)據(jù)庫" + urlType);
}
}
}
//測試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);
}
補充一張圖

浙公網(wǎng)安備 33010602011771號