适配器模式(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);
- }
- }
- }
- /**
- * 默认查询分页类
- */
- 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);
- }
复制代码 补充一张图
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |