posts - 12,  comments - 0,  views - 1321
< 2025年1月 >
29 30 31 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 1
2 3 4 5 6 7 8

适配器模式(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类写固定代码, 各个子类 写 特殊代码

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);
    }

  补充一张图

 

  

 

posted on   zy平平仄仄  阅读(385)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 20250116 支付宝出现重大事故 有感
· 一个基于 Roslyn 和 AvalonEdit 的跨平台 C# 编辑器
· 推荐一款非常好用的在线 SSH 管理工具
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· .NET周刊【1月第1期 2025-01-05】
点击右上角即可分享
微信分享提示