问题描述
当一个抽象有多种不同的实现方式的时候,继承是一种典型的方法;但是这种方式让抽象和实现静态绑定。如何让一个面向客户的抽象接口,和实现该抽象接口的具体实现相隔离?如何让抽象接口和实现该抽象的实现接口独立变化?桥接模式让抽象接口及其具体实现解耦。
桥接模式
如图所示,桥接模式定义了两个抽象接口:Abstraction和Implementor接口。Abstraction接口为客户提供使用方便的接口;Implementor接口为Abstraction接口提供一种实现方案,通常较Abstraction更底层。Abstraction对象调度Implementor对象的接口方法来实现Abstraction接口。桥接模式分离了Abstraction接口和Implementor接口,让这两个接口独立变化成为可能。例如:RefinedAbstraction接口扩展Abstraction接口,为客户提供新的接口;这个新接口可能是基于Implementor接口实现,也可能完全和Implementor无关。相似的,Implementor接口也可以存在两种不同的实现:即ConcreteImplementorA和ConcreteImplementorB;而这两种实现方式也和Abstractor接口没有直接相关性。
讨论
桥接模式在对象结构上和适配器模式相似,这两个模式的区别在于
- 模式的目的:适配器模式是匹配两个不兼容的接口;桥接模式则是让接口及其具体实现接口相隔离;
- 模式的效果:适配器模式实现代码重用;桥接模式让两个接口的独立变化。