桥梁模式的定义

定义: 将抽象和实现解耦, 使得两者可以独立的变化

通俗的说, 就是一个类调用另一个类中的方法, 需要一个桥梁, 通过聚合的关系调用

其类图如下:

其中角色说明如下:

  1. Abstraction 抽象化角色: 它的主要职责是定义出该角色的行为, 同时保存一个对实现化角色的引用, 一般是抽象类
  2. Implementor 实现化角色: 接口或抽象类, 定义角色必须的行为和属性
  3. RefinedAbstraction 修正抽象化角色: 它引用实现化角色对抽象化角色进行修正
  4. ConcreteImplementor 具体实现化角色: 它实现接口或抽象类定义的方法和属性

抽象角色的部分实现是由实现角色完成的

实现化角色代码:

具体实现化角色代码:

抽象化角色代码:

具体抽象化角色代码:

场景类代码:

桥梁模式是一个很简单的模式, 它只是使用了类间的聚合关系、继承、覆写等常用功能, 但是它却提供了一个非常清晰、稳定的架构.

桥梁模式的应用

桥梁模式的优点:

  1. 抽象和实现分离. 这是桥梁模式的主要特点, 它完全是为了解决继承的缺点而提出的设计模式. 在该模式下,实现可以不受抽象的约束,不用再绑定在一个固定的抽象层次上
  2. 优秀的扩充能力.
  3. 实现细节对客户透明. 客户不用关心细节的实现, 它已经由抽象层通过聚合关系完成了封装

桥梁模式的使用场景:

  1. 不希望或不适用使用继承的场景. 例如继承层次过滤、无法更细化设计颗粒等场景
  2. 接口或抽象类不稳定的场景.
  3. 重用性要求较高的场景. 设计的颗粒度越细,则被重用的可能性就越大, 而采用继承则受父类的限制, 不可能出现太细的颗粒度

使用桥梁模式主要考虑如何拆分抽象和实现,并不是一设计继承就要考虑使用该模式. 桥梁模式的意图还是对变化的封装, 尽量把可能变化的因素封装到最细、最小的逻辑单元中,避免风险扩散.因此在进行系统设计时,发现类的继承有N层时,可以考虑使用桥梁模式


桥梁模式在Java应用中的一个非常典型的例子就是JDBC驱动器。JDBC为所有的关系型数据库提供一个通用的界面。一个应用系统动态地选择一个合适的驱动器,然后通过驱动器向数据库引擎发出指令。这个过程就是将抽象角色的行为委派给实现角色的过程。

抽象角色可以针对任何数据库引擎发出查询指令,因为抽象角色并不直接与数据库引擎打交道,JDBC驱动器负责这个底层的工作。由于JDBC驱动器的存在,应用系统可以不依赖于数据库引擎的细节而独立地演化;同时数据库引擎也可以独立于应用系统的细节而独立的演化。两个独立的等级结构如下图所示,左边是JDBC API的等级结构,右边是JDBC驱动器的等级结构。应用程序是建立在JDBC API的基础之上的。

应用系统作为一个等级结构,与JDBC驱动器这个等级结构是相对独立的,它们之间没有静态的强关联。应用系统通过委派与JDBC驱动器相互作用,这是一个桥梁模式的例子。

JDBC的这种架构,把抽象部分和具体部分分离开来,从而使得抽象部分和具体部分都可以独立地扩展。对于应用程序而言,只要选用不同的驱动,就可以让程序操作不同的数据库,而无需更改应用程序,从而实现在不同的数据库上移植;对于驱动程序而言,为数据库实现不同的驱动程序,并不会影响应用程序。

23种设计模式之桥梁模式相关推荐

  1. 23种设计模式——装饰者模式

    文章目录 23种设计模式--装饰者模式 1.装饰者模式概述 2.装饰者模式的结构 3.装饰者模式的实现 4.装饰者模式的应用场景 23种设计模式--装饰者模式 1.装饰者模式概述 背景 有些人为了早上 ...

  2. 实践GoF的23种设计模式:建造者模式

    本文分享自华为云社区<[Go实现]实践GoF的23种设计模式:建造者模式>,作者: 元闰子. 简述 在程序设计中,我们会经常遇到一些复杂的对象,其中有很多成员属性,甚至嵌套着多个复杂的对象 ...

  3. 【Go实现】实践GoF的23种设计模式:命令模式

    上一篇:[Go实现]实践GoF的23种设计模式:代理模式 简单的分布式应用系统(示例代码工程):https://github.com/ruanrunxue/Practice-Design-Patter ...

  4. 23种设计模式7_代理模式之一静态代理

    23种设计模式7_代理模式之一静态代理 1 基本介绍 代理模式:为其他对象提供一种代理以控制对这个对象的访问 代理模式也叫委托模式,它是一项基本设计技巧.许多其他的模式,如状态模式.策略模式.访问者模 ...

  5. 23种设计模式之命令模式和策略模式的区别

    文章目录 概述 命令模式 策略模式 相同点 总结 概述 命令模式和策略模式确实很相似,只是命令模式多了一个接收者(Receiver)角色.它们虽然同为行为类模式,但是两者的区别还是很明显的.策略模式的 ...

  6. 23种设计模式之代理模式

    文章目录 代理模式的定义与特点 代理模式的结构与实现 模式的结构 模式的实现 代理模式的应用场景 代理模式的应用实例 代理模式的扩展 代理模式分类 静态代理 动态代理 在有些情况下,一个客户不能或者不 ...

  7. 23种设计模式----中介者模式----行为型模式

    中介者模式 1.什么是中介者模式 2.中介者模式的角色 3.例子 3.1 项目结构 3.2 共同实体 3.3 抽象的中介者 3.4 抽象的被中介者 3.5 具体的中介者 3.6 具体的被中介者 3.7 ...

  8. 2.5万字详解23种设计模式—创建型模式(简单工厂、工厂方法、抽象工厂、单例-多线程安全详解、建造者、原型)的详细解读、UML类图

    本文简述了各大设计模式,并通过UML和代码详细说明.本文大约共 2.5W 字,建议收藏.下方是本文的目录: 一.设计模式的认识 二.设计模式的分类 根据其目的 根据范围 三.设计模式的优点 四.设计模 ...

  9. 23种设计模式-行为型模式-访问者模式

    在患者就医时,医生会根据病情开具处方单,很多医院都会存在以下这个流程:划价人员拿到处方单之后根据药品名称和数量计算总价,而药房工作人员根据药品名称和数量准备药品,如下图所示. 在软件开发中,有时候也需 ...

最新文章

  1. Apache PHP7 多站点 多端口的配置
  2. vbs删除非空文件夹
  3. 【MFC】根据菜单创建工具栏
  4. jenkins2 groovy语法
  5. 3个观念 不再瞎学习!
  6. 如何用c语言编写工程文件夹,利用makefile实现c语言项目编译
  7. 万网域名注册查询接口(API)的说明
  8. 对话清华NLP实验室刘知远:NLP搞事情少不了知识库与图神经网络
  9. 2Do for Mac(任务管理GTD工具)
  10. 吴恩达机器学习视频笔记和编程作业(Python实现)汇总
  11. PHP实现打印出库单,有没有实现过?
  12. selenium 模拟火狐浏览器
  13. 《北京市住房租赁条例》
  14. s3cmd常用命令和使用技巧
  15. 负反馈放大电路实验报告
  16. 云计算要掌握哪些知识点 该怎么学云计算开发
  17. 利用Java计算圆柱体积
  18. 脊髓空洞症先知先觉早期症状
  19. 游戏设计模式-观察者模式
  20. Go基础:for循环

热门文章

  1. STM32与MS5837压力传感器的I2C通讯
  2. idea插件开发(01)---最简单的helloworld版,不需要知道原理,先跟我做一个最简单的弹框插件
  3. mysql slave同步_Slave_SQL_Running: No mysql同步故障解决方法
  4. 5gh掌上云计算认证不通过_阿里云ACP认证考试攻略、考试心得、费用及常见问题...
  5. php fckeditor demo,如何使用PHP添加fckeditor
  6. python通讯录运用的知识点_案例驱动式Python学习--通讯录存取
  7. 程序员肚子越来越大_肚子越来越大,除了肥胖还可能是疾病信号!腰间搓一搓,排出痰浊,消脂防病~...
  8. linux卸载openjdk_Linux系列(七)——linux其他指令【rpm、yum、sudo】
  9. oracle 谭岚_Hibernate实现Oracle BLOB的数据读写(2)
  10. 10大最高效的Java库盘点