Bridge(桥接)
一、意图
将抽象部分与其实现部分分离,使它们都可以独立地变化。
二、结构
桥接模式的结构如图7-32所示。
其中:
• Abstraction定义抽象类的接口,维护一个指向Implementor类型对象的指针。
• RefinedAbstraction 扩充由 Abstraction 定义的接口。
• Implementor定义实现类的接口,该接口不一定要与Abstraction的接口完全一致:事实上这两个接口可以完全不同。一般来说,Implementor接口仅提供基本操作,而 Abstraction定义了基于这些基本操作的较高层次的操作。
• ConcreteImplementor实现Implementor接口并定义它的具体实现。
三、适用性
Bridge模式适用于:
• 不希望在抽象和它的实现部分之间有一个固定的绑定关系。例如,这种情况可能是因为,在程序运行时刻实现部分应可以被选择或者切换。
• 类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充。这是Bridge模式使得开发者可以对不同的抽象接口和实现部分进行组合,并分别对它们进行扩充。
• 对一个抽象的实现部分的修改应对客户不产生影响,即客户代码不必重新编译。
• 有许多类要生成的类层次结构。
• 想在多个对象间共享实现(可能使用引用计数),但同时要求客户并不知道这一点。
四、实现
首先 定义品牌接口和具体品牌
。
// 电脑品牌
interface Brand {
void sale();
}
// 创建电脑牌子
class Lenovo implements Brand {
@Override
public void sale() {
System.out.print("出售联想的");
}
}
class Dell implements Brand {
@Override
public void sale() {
System.out.print("出售戴尔的");
}
}
// 新增牌子是十分方便的
class Shenzhou implements Brand {
@Override
public void sale() {
System.out.print("出售神州的");
}
}
然后 定义一个电脑类,分别用笔记本和台式来继承它
。
//电脑类型+ 获得 品牌的引用
class Computer {
protected Brand brand;
public Computer(Brand b) {
this.brand = b;
}
public void sale(){
brand.sale();
}
}
//创建电脑类型
class Desktop extends Computer {
public Desktop(Brand b) {
super(b);
}
@Override
public void sale() {
super.sale();
System.out.println("台式电脑");
}
}
class Laptop extends Computer {
public Laptop(Brand b) {
super(b);
}
@Override
public void sale() {
super.sale();
System.out.println("笔记本");
}
}
最后 测试一下
。
public class Bridge {
public static void main(String[] args) {
// TODO Auto-generated method stub
// 这样就笔记轻松的获得牌子 + 类型
Lenovo lenovo = new Lenovo();
Dell dell = new Dell();
Shenzhou shenzhou = new Shenzhou();
Computer c1 = new Laptop(lenovo);
c1.sale();
Computer c2 = new Laptop(dell);
c2.sale();
Computer c3 = new Laptop(shenzhou);
c3.sale();
System.out.println("========================");
Computer c4 = new Desktop(lenovo);
c4.sale();
Computer c5 = new Desktop(dell);
c5.sale();
Computer c6 = new Desktop(shenzhou);
c6.sale();
}
}
运行结果: