设计模式之桥接模式
定义
就像一个桥,将两个变化维度连接起来,各个维度都可以独立的变化,故称为:桥接模式
介绍
桥接模式(Bridge)将抽象部分与实现部分分离,使他们都可以独立的变化。桥接模式是一种结构式的模式,它通过提供抽象化和实现化之间的桥接结构,来实现二者的解耦。多重继承方案往往违背了类得单一职责原则,其复用性比较差,桥接模式是比多重继承方案更好的解决方案。
核心要点
处理多层继承结构,处理多维度变化的场景,将各个维度设计成独立的继承结构,使各个维度可以独立的扩展在抽象层建立关联。
类图
例子:电脑类型和品牌
代码如下
定义接口
/**
* 品牌的接口(品牌维度)
* @author mama
*
*/
public interface Brand {
void sale();
}
定义接口的实现类
/**
* 品牌的实现类
* @author mama
*
*/
class Lenovo implements Brand {
@Override
public void sale() {
System.out.println("销售联想电脑");
}
}
class Dell implements Brand {
@Override
public void sale() {
System.out.println("销售Dell电脑");
}
}
定义抽象接口
/**
* 电脑类型的维度
* @author mama
*
*/
public abstract class Computer2 {
// 持有一个 brand 对象,形成聚合关系
protected Brand brand;
public Computer2(Brand brand) {
super();
this.brand = brand;
}
// 可能需要转调实现部分的具体实现
public void sale(){
brand.sale();
}
}
定义抽象实现类
class Desktop2 extends Computer2{
public Desktop2(Brand brand) {
super(brand);
}
@Override
public void sale() {
super.sale();
System.out.println("销售台式机");
}
}
测试
public class Client {
public static void main(String[] args) {
//销售联想的笔记本电脑
Computer2 c=new Desktop2(new Lenovo());
c.sale();
}
}
优点
(1) 可以将接口与实现相分离。
(2) 提高了可扩展性。
(3) 对客户端隐藏了实现的细节
应用场景
1、如果你不希望在抽象和实现部分采用固定的绑定关系,可以采用桥接模式,来把抽象和实现部分分开,然后在程序运行期间来动态的设置抽象部分需要用到的具体的实现,还可以动态切换具体的实现。
2、如果出现抽象部分和实现部分都应该可以扩展的情况,可以采用桥接模式,让抽象部分和实现部分可以独立的变化,从而可以灵活的进行单独扩展,而不是搅在一起,扩展一边会影响到另一边。
3、如果希望实现部分的修改,不会对客户产生影响,可以采用桥接模式,客户是面向抽象的接口在运行,实现部分的修改,可以独立于抽象部分,也就不会对客户产生影响了,也可以说对客户是透明的。
4、如果采用继承的实现方案,会导致产生很多子类,对于这种情况,可以考虑采用桥接模式,分析功能变化的原因,看看是否能分离成不同的纬度,然后通过桥接模式来分离它们,从而减少子类的数目。
总结
(1)桥接模式可以取代多层继承的方案,多层继承违背了单一职责原则,复用性较差,类的个数也非常多,桥接模式可以极大的减少子类的个数,从而降低管理和维护的成本
(2)桥接模式极大的提高了系统的可扩展性,在两个变化维度中任意扩展一个维度,都不需要修改原有的系统,符合开闭原则。