概念:在软件系统中如果存在两个以上的独立变化的维度,可以通过桥接模式将这两个维度分离出来,使之可以独立的扩展,让系统更加符合“单一职责原则”,与多层继承的方式不同,它将两个独立变化的维度设计成两个独立的等级继承结构。
它将它的抽象部分和实现部分分离,使之可以独立的变化,
角色:
Abstraction: 抽象类接口,一般是一个抽象类,而不是一个接口,其中关联了一个Implementor ,通过这种组合的形式,在Abstraction中不仅有自己的方法,还可以调用到Implementor中的方法,用组合替代继承;可以抽象业务方法,也可以有具体的业务方法。
Implementor :实现类接口,一般而言,Implementor只提供基本的操作,而在Abstraction中可能会做更多复杂的操作。
RefinedAbstraction:扩充抽象类,它会实现Abstraction中的方法,可以通过扩充抽象类调用Implementor中的方法。
ConcreteImplementor: 具体实现Implementor接口。
优点:
1 分离抽象接口和其实现部分:桥接模式使用对象间的关联关系“解耦抽象和实现之间的固有的绑定关系,使得抽象和实现之间沿着各自的维度变化,也就是说抽象和实现不在同一个继承结构当中”。
2 桥接模式可以很好的取代多层继承方案,多层继承方案违反了“单一职责原则”,复用性较差,且类的个数非常多。
3 桥接模式提高了系统的可扩展性,在两个变化的维度任意扩展一个维度,都不需要修改原来的系统。
缺点:
(1)桥接模式的使用会增加系统的理解与设计难度,由于关联关系建立在抽象层,要求开发者一开始就针对抽象层进行设计与编程。
(2)桥接模式要求正确识别出系统中两个独立变化的维度,因此其使用范围具有一定的局限性,如何正确识别两个独立维度也需要一定的经验积累
使用场景:
一个类存在两个独立变化的维度,并且这两个维度都需要进行扩展。
如果一个系统需要在构件抽象化角色和实现类角色之间增加更多的灵活性,避免在两个层次之间建立静态的继承关系,可以通过桥接模式使它们在抽象层建立一个关联。
对于那些不希望使用继承或者因为多层次的继承会导致系统类的个数急剧增加的系统也可以使用桥接模式。
Android中的应用: