Skip to content

Latest commit

 

History

History

bridge

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

桥接模式 Bridge

✨模式类型✨✨ ✨✨难度✨ ✨ ✨✨实用性✨✨ ✨✨重要程度✨✨ ✨✨经典性✨✨ ✨✨历史性✨
结构型模式 ★★★ ⬇️ ★★★★ ⬆️ ★★★★ ⬆️ 💚 ⬆️ 💚 ⬆️

概念

桥接模式(Bridge Pattern):将抽象部分与它的实现部分分离,使它们都可以独立地变化。它是一种对象结构型模式,又称为柄体(Handle and Body)模式接口(Interface)模式。简单的说:桥模式更倾向于组合而不是继承,实现细节从层次结构推送到具有单独层次结构的另一个对象。桥接模式将继承关系转换为关联关系,从而降低了类与类之间的耦合,减少了代码编写量

用途

桥接模式就是把事物和其具体实现分开,使他们可以各自独立的变化。桥接的用意是:将抽象化与实现化解耦,使得二者可以独立变化。在有多种可能会变化的情况下,用继承会造成类爆炸问题,扩展起来不灵活

模式架构

桥接模式的重点是理解如何将抽象化(Abstraction)与实现化(Implementation)解耦,使得二者可以独立地变化

  • 抽象化:抽象化就是忽略一些信息,把不同的实体当作同样的实体对待。在面向对象中,将对象的共同性质抽取出来形成类的过程即为抽象化的过程。
  • 实现化:针对抽象化给出的具体实现,就是实现化,抽象化与实现化是一对互逆的概念,实现化产生的对象比抽象化更具体,是对抽象化事物的进一步具体化的产物
  • 解耦:解耦就是将抽象化和实现化之间的耦合解开,或者说是将它们之间的强关联改换成弱关联,将两个角色之间的继承关系改为关联关系。桥接模式中的所谓解耦,就是指在一个软件系统的抽象化和实现化之间使用关联关系(组合或者聚合关系)而不是继承关系,从而使两者可以相对独立地变化,这就是桥接模式的用意。

参与角色对象

  • Abstraction 定义抽象类的接口:完成最终业务对象业务逻辑接口的定义
  • RefinedAbstraction 扩充抽象类:继承Abstraction,使用组合利用Implementor实现Abstraction父类的方法
  • Implementor 定义实现类接口:定义对应于Abstraction的相关方法实现,可以加入相应的业务逻辑行为
  • ConcreteImplementor 具体实现类:继承Implementor类并实现其所有方法

UML关系图

1541208884367

优点与缺点

  • 优点

    • 抽象和实现的分离分离抽象接口及其实现部分。
    • 桥接模式有时类似于多继承方案,但是多继承方案违背了类的单一职责原则(即一个类只有一个变化的原因),复用性比较差,而且多继承结构中类的个数非常庞大,桥接模式是比多继承方案更好的解决方法。
    • 优秀的扩展能力:桥接模式提高了系统的可扩充性,在两个变化维度中任意扩展一个维度,都不需要修改原有系统
    • 实现细节对客户透明:可以对用户隐藏实现细节
  • 缺点

    • 桥接模式的引入会增加系统的理解与设计难度,由于聚合关联关系建立在抽象层,要求开发者针对抽象进行设计与编程
    • 桥接模式要求正确识别出系统中两个独立变化的维度,因此其使用范围具有一定的局限性

代码实现

桥接模式的实现要点如下:

  • 首先定义 Abstraction 抽象类的接口,完成最终业务对象业务逻辑接口的定义;
  • Abstraction需要组合 Implementor 类,借助Implementor 类实现在Abstraction子类中完成业务。

示例参考

应用场景

桥接模式适用于:

  • 避免抽象与其实现之间的永久绑定。例如,必须在运行时选择或切换实现时可能就是这种情况。
  • 抽象及其实现都应该通过子类化来扩展。在这种情况下,桥接模式允许组合不同的抽象和实现并独立扩展它们。
  • 抽象实现的变化应该对客户没有影响, 也就是说,他们的代码不应该被重新编译。
  • 多个对象之间共享一个实现(可能使用引用计数),这个事实应该从客户端隐藏。一个简单的例子是CoplienString类,其中多个对象可以共享相同的字符串表示。
  • 对于那些不希望使用继承或因为多层次继承导致系统类的个数急剧增加的系统,桥接模式尤为适用。
  • 一个类存在两个独立变化的维度,且这两个维度都需要进行扩展
  • 如果一个系统需要在构件的抽象化角色和具体化角色之间增加更多的灵活性,避免在两个层次之间建立静态的继承联系,通过桥接模式可以使它们在抽象层建立一个关联关系。

应用实例参考

JavaSDK

  • AWT (It provides an abstraction layer which maps onto the native OS the windowing support.)
  • JDBC

GoSDK

PythonSDK

JavaScript Libs

总结

  • 桥接模式将抽象部分与它的实现部分分离,使它们都可以独立地变化。它是一种对象结构型模式,又称为柄体(Handle and Body)模式或接口(Interface)模式。
  • 简单的说:桥模式更倾向于组合而不是继承,实现细节从层次结构推送到具有单独层次结构的另一个对象。桥接模式将继承关系转换为关联关系,从而降低了类与类之间的耦合,减少了代码编写量
  • 桥接的用意是:将抽象化与实现化解耦,使得二者可以独立变化。在有多种可能会变化的情况下,用继承会造成类爆炸问题,扩展起来不灵活。
  • 桥接模式的参与角色有:Abstraction 定义抽象类的接口、RefinedAbstraction扩充抽象类、Implementor定义实现类接口、ConcreteImplementor具体实现类。
  • 桥接模式优点有:抽象和实现的分离、优秀的扩展能力、细节对客户透明
  • 桥接模式适用于:避免抽象与其实现之间的永久绑定、抽象及其实现都应该通过子类化来扩展、抽象实现的变化应该对客户没有影响、多个对象之间共享一个实现