当前位置:   article > 正文

设计模式(十)——结构型模式——桥接模式(Bridge)_骨架类 桥接模式

骨架类 桥接模式

定义:将抽象与实现分离,使它们可以独立变化。它是用组合关系代替继承关系来实现,从而降低了抽象和实现这两个可变维度的耦合度。如果软件系统中某个类存在两个独立变化的维度,通过该模式可以将这两个维度分离出来,使两者可以独立扩展,让系统更加符合“单一职责原则”。

优点:由于抽象与实现分离,所以扩展能力强;其实现细节对客户透明。

缺点:由于聚合关系建立在抽象层,要求开发者针对抽象化进行设计与编程,这增加了系统的理解与设计难度。

结构与实现

可以将抽象化部分与实现化部分分开,取消二者的继承关系,改用组合关系。

主要角色

(1)抽象化(Abstraction)角色:定义抽象类,并包含一个对实现化对象的引用。

(2)扩展抽象化(Refined Abstraction)角色:是抽象化角色的子类,实现父类中的业务方法,并通过组合关系调用实现化角色中的业务方法。

(3)实现化(Implementor)角色:定义实现化角色的接口,供扩展抽象化角色调用。

(4)具体实现化(Concrete Implementor)角色:给出实现化角色接口的具体实现。

 

  1. public class BridgeTest
  2. {
  3. public static void main(String[] args)
  4. {
  5. Implementor imple=new ConcreteImplementorA();
  6. Abstraction abs=new RefinedAbstraction(imple);
  7. abs.Operation();
  8. }
  9. }
  10. //实现化角色
  11. interface Implementor
  12. {
  13. public void OperationImpl();
  14. }
  15. //具体实现化角色
  16. class ConcreteImplementorA implements Implementor
  17. {
  18. public void OperationImpl()
  19. {
  20. System.out.println("具体实现化(Concrete Implementor)角色被访问" );
  21. }
  22. }
  23. //抽象化角色
  24. abstract class Abstraction
  25. {
  26. protected Implementor imple;
  27. protected Abstraction(Implementor imple)
  28. {
  29. this.imple=imple;
  30. }
  31. public abstract void Operation();
  32. }
  33. //扩展抽象化角色
  34. class RefinedAbstraction extends Abstraction
  35. {
  36. protected RefinedAbstraction(Implementor imple)
  37. {
  38. super(imple);
  39. }
  40. public void Operation()
  41. {
  42. System.out.println("扩展抽象化(Refined Abstraction)角色被访问" );
  43. imple.OperationImpl();
  44. }
  45. }

桥接模式的应用

(1)当一个类存在两个独立变化的维度,且这两个维度都需要进行扩展时。

(2)当一个系统不希望使用继承或因为多层次继承导致系统类的个数急剧增加时。

(3)当一个系统需要在构件的抽象化角色和具体化角色之间增加更多的灵活性时。

桥接模式的扩展

在软件开发中,有时桥接(Bridge)模式可与适配器模式联合使用。当桥接(Bridge)模式的实现化角色的接口与现有类的接口不一致时,可以在二者中间定义一个适配器将二者连接起来

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/568975
推荐阅读
相关标签
  

闽ICP备14008679号