适配器模式(Adapter Pattern)
结构型设计模式,见名知意,就是两个不兼容的接口之间的桥梁。它结合了两个独立接口的功能。
主要解决:常常要将一些"现存的对象"放到新的环境中,而新环境要求的接口是现对象不能满足的。
关键代码:适配器继承或依赖已有的对象,实现想要的目标接口。
优点: 1、可以让任何两个没有关联的类一起运行。 2、提高了类的复用。 3、增加了类的透明度。 4、灵活性好。
缺点: 1、过多地使用适配器,会让系统非常零乱,不易整体进行把握。 2.由于 JAVA 至多继承一个类,所以至多只能适配一个适配者类,而且目标类必须是抽象类。
组成:
注意事项:适配器不是在详细设计时添加的,而是解决正在服役的项目的问题。
======================================================== 以上八股文 来源 菜鸟================================================================================================
举个小例子:
某个程序,最初设计是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类写固定代码, 各个子类 写 特殊代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 | /** * 基础分页接口 */ 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); } } } /** * 默认查询分页类 */ 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); } } } //测试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); } |
补充一张图
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 20250116 支付宝出现重大事故 有感
· 一个基于 Roslyn 和 AvalonEdit 的跨平台 C# 编辑器
· 推荐一款非常好用的在线 SSH 管理工具
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· .NET周刊【1月第1期 2025-01-05】