设计模式——桥接模式

桥接(Bridge)模式

一、基本思想

当一个类内部具备两种或多种变化维度时,使用桥接模式可以解耦这些变化的维度,使高层代码架构稳定。

将抽象与实现分离,使它们可以独立变化。

组合关系代替继承关系来实现,从而降低了抽象和实现这两个可变维度的耦合度。

特点:遵循了里氏替换原则和依赖倒置原则,最终实现了开闭原则,对修改关闭,对扩展开放。

二、应用场景

  1. 当一个类存在两个独立变化的维度,且这两个维度都需要进行扩展。
  2. 当一个系统不希望使用继承或因为多层次继承导致系统类的个数急剧增加。
  3. 当一个系统需要在构件的抽象化角色和具体化角色之间增加更多的灵活性。

分不清该使用继承还是组合/聚合或其他方式等,其实可以从现实语义进行思考。软件是具备现实场景的。

桥接模式的一个常见使用场景就是替换继承。我们知道,继承拥有很多优点,比如,抽象、封装、多态等,父类封装共性,子类实现特性。继承可以很好的实现代码复用(封装)的功能,但这也是继承的一大缺点。

因为父类拥有的方法,子类也会继承得到,无论子类需不需要,这说明继承具备强侵入性(父类代码侵入子类),同时会导致子类臃肿。因此,在设计模式中,有一个原则为优先使用组合/聚合,而不是继承。

三、结构图

设计模式——桥接模式_第1张图片

  1. 抽象化(Abstraction)角色:定义抽象类,并包含一个对实现化对象的引用。
  2. 扩展抽象化(Refined Abstraction)角色:是抽象化角色的子类,实现父类中的业务方法,并通过组合关系调用实现化角色中的业务方法。
  3. 实现化(Implementor)角色:定义实现化角色的接口,供扩展抽象化角色调用。
  4. 具体实现化(Concrete Implementor)角色:给出实现化角色接口的具体实现。

四、代码实现

设计模式——桥接模式_第2张图片

五、优缺点

优点:
  1. 抽象与实现分离,扩展能力强
  2. 符合开闭原则
  3. 符合合成复用原则
  4. 其实现细节对客户透明
缺点:
  1. 由于聚合关系建立在抽象层,要求开发者针对抽象化进行设计与编程,能正确地识别出系统中两个独立变化的维度,这增加了系统的理解与设计难度。

六、桥接模式的扩展

在软件开发中,有时桥接模式可与适配器模式联合使用。

当桥接(Bridge)模式的实现化角色的接口与现有类的接口不一致时,可以在二者中间定义一个适配器将二者连接起来。
设计模式——桥接模式_第3张图片

你可能感兴趣的:(设计模式,设计模式,桥接模式,java,后端,面试)