找回密码
 立即注册
首页 业界区 业界 java 适配器模式

java 适配器模式

嫁蝇 4 天前
适配器模式(Adapter Pattern)
  结构型设计模式,见名知意,就是两个不兼容的接口之间的桥梁。它结合了两个独立接口的功能。
  主要解决:常常要将一些"现存的对象"放到新的环境中,而新环境要求的接口是现对象不能满足的。
  关键代码:适配器继承或依赖已有的对象,实现想要的目标接口。
  优点: 1、可以让任何两个没有关联的类一起运行。 2、提高了类的复用。 3、增加了类的透明度。 4、灵活性好。
  缺点: 1、过多地使用适配器,会让系统非常零乱,不易整体进行把握。 2.由于 JAVA 至多继承一个类,所以至多只能适配一个适配者类,而且目标类必须是抽象类。
  组成:
    1.目标(target)标准接口    2.源头(source)不兼容对象    3.适配器 (adapter)转换不兼容对象为标准接口  注意事项:适配器不是在详细设计时添加的,而是解决正在服役的项目的问题。
======================================================== 以上八股文 来源  菜鸟================================================================================================
举个小例子:
  某个程序,最初设计是mysql 数据库, 分页的 关键字是 limit, 程序被卖了两家公司,一家公司是 db2数据库, 一家公司是 Oracle数据库 , 程序的sql 语句 需要兼容 两家数据库的  分页 关键字,且不能丢掉原有的, 这个时候就可以使用适配器模式, 适配其他两种数据库的关键字 。
1.png

代码如下:
   
  1. /**
  2. * 基础分页接口
  3. */
  4. public interface BasePage {
  5.     public void page(String urlType,String sql);
  6. }
  7. /**
  8. * 其他分页接口(Oracle,DB2)
  9. */
  10. public interface OtherPage {
  11.     void oraclePage(String sql);
  12.     void db2Page(String sql);
  13. }
  14. /**
  15. * Oracle 的实现
  16. */
  17. public class OraclePage implements OtherPage{
  18.     @Override
  19.     public void oraclePage(String sql) {
  20.         String oracleSql = sql.replace("limit","ROW_NUMBER");
  21.         System.out.println("oracle: " + oracleSql);
  22.     }
  23.     @Override
  24.     public void db2Page(String sql) {}
  25. }
  26. /**
  27. * db2 的实现
  28. */
  29. public class DB2Page implements OtherPage{
  30.     @Override
  31.     public void oraclePage(String sql) {}
  32.     @Override
  33.     public void db2Page(String sql) {
  34.         String db2Sql  = sql.replace("limit","RowNumber");//为了区分Oracle的ROW_NUMBER 改为驼峰式
  35.         System.out.println("DB2 : " + db2Sql);
  36.     }
  37. }
  38. /**
  39. * 适配器
  40. */
  41. public class PageAdapter implements BasePage{
  42.     OtherPage otherPage;
  43.     @Override
  44.     public void page(String urlType, String sql) {
  45.         if(urlType.contains("db2")){
  46.             otherPage = new DB2Page();
  47.             otherPage.db2Page(sql);
  48.         }else if(urlType.contains("oracle")){
  49.             otherPage = new OraclePage();
  50.             otherPage.oraclePage(sql);
  51.         }
  52.     }
  53. }
  54. /**
  55. * 默认查询分页类
  56. */
  57. public class SelectPage implements BasePage {
  58.     PageAdapter pageAdapter;
  59.     @Override
  60.     public void page(String urlType, String sql) {
  61.         if (urlType.contains("mysql")) {
  62.             System.out.println("mysql : " + sql);
  63.         } else if (urlType.contains("db2") || urlType.contains("oracle")) {
  64.             pageAdapter = new PageAdapter();
  65.             pageAdapter.page(urlType, sql);
  66.         } else {
  67.             System.err.println("不支持的数据库" + urlType);
  68.         }
  69.     }
  70. }
  71. //测试执行
  72.     public static void main(String[] args) {
  73.         String sql = " select * from xxxx  limit xx; ";
  74.         SelectPage selectPage = new SelectPage();
  75.         selectPage.page("jdbc:mysql://xxxxxxxxxxx",sql);
  76.         selectPage.page("jdbc:db2://xxxxxxxxxxx",sql);
  77.         selectPage.page("jdbc:oracle://xxxxxxxxxxx",sql);
  78.         selectPage.page("jdbc:sqlserver://xxxxxxxxxxx",sql);
  79.     }
复制代码
结果:
2.png

 ==========================================收工=================================================================================
补充一个 代码, 特定业务场景会用到, 需要琢磨一下,Abstract类写固定代码, 各个子类 写 特殊代码
  1. /**
  2. * 基础分页接口
  3. */
  4. public interface BasePage {
  5.     public void page(String urlType,String sql);
  6. }
  7. /**
  8. * 其他分页接口(Oracle,DB2)
  9. */
  10. public interface OtherPage {
  11.     void oraclePage(String sql);
  12.     void db2Page(String sql);
  13. }
  14. /**
  15. * 抽象类
  16. */
  17. public abstract class AbstractOtherPageClass implements OtherPage {
  18.     @Override
  19.     public void oraclePage(String sql) {
  20.         String oracleSql = sql.replace("limit","ROW_NUMBER");
  21.         System.out.println("oracle: " + oracleSql);
  22.     }
  23.     @Override
  24.     public void db2Page(String sql) {
  25.         String db2Sql  = sql.replace("limit","RowNumber");//为了区分Oracle的ROW_NUMBER 改为驼峰式
  26.         System.out.println("DB2 : " + db2Sql);
  27.     }
  28. }
  29. /**
  30. * OraclePage 继承抽象类,不需要实现所有接口
  31. */
  32. public class OraclePage extends AbstractOtherPageClass{
  33.     @Override
  34.     public void oraclePage(String sql) {
  35.         super.oraclePage(sql);
  36.         //子类特有方法
  37.     }
  38. }
  39. /**
  40. * db2 继承抽象类,不需要实现所有接口
  41. */
  42. public class DB2Page extends AbstractOtherPageClass{
  43.     @Override
  44.     public void db2Page(String sql) {
  45.         super.db2Page(sql);
  46.         //子类特有方法
  47.     }
  48. }
  49. /**
  50. * 适配器 继承 抽象类,实现 基类。也可以new 子类对象
  51. */
  52. public class PageAdapter extends AbstractOtherPageClass implements BasePage {
  53. //    OtherPage otherPage;
  54.     @Override
  55.     public void page(String urlType, String sql) {
  56.         if(urlType.contains("db2")){
  57.             super.db2Page(sql);
  58. //            otherPage = new DB2Page();
  59. //            otherPage.db2Page(sql);
  60.         }else if(urlType.contains("oracle")){
  61.             super.oraclePage(sql);
  62. //            otherPage = new OraclePage();
  63. //            otherPage.oraclePage(sql);
  64.         }
  65.     }
  66. }
  67. /**
  68. * 默认查询分页类
  69. */
  70. public class SelectPage implements BasePage {
  71.     PageAdapter pageAdapter;
  72.     @Override
  73.     public void page(String urlType, String sql) {
  74.         if (urlType.contains("mysql")) {
  75.             System.out.println("mysql : " + sql);
  76.         } else if (urlType.contains("db2") || urlType.contains("oracle")) {
  77.             pageAdapter = new PageAdapter();
  78.             pageAdapter.page(urlType, sql);
  79.         } else {
  80.             System.err.println("不支持的数据库" + urlType);
  81.         }
  82.     }
  83. }
  84. //测试main方法
  85.     public static void main(String[] args) {
  86.         String sql = " select * from xxxx  limit xx; ";
  87.         SelectPage selectPage = new SelectPage();
  88.         selectPage.page("jdbc:mysql://xxxxxxxxxxx",sql);
  89.         selectPage.page("jdbc:db2://xxxxxxxxxxx",sql);
  90.         selectPage.page("jdbc:oracle://xxxxxxxxxxx",sql);
  91.         selectPage.page("jdbc:sqlserver://xxxxxxxxxxx",sql);
  92.     }
复制代码
  补充一张图
3.png

 
  
 

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册