桥梁模式
定义
将抽象和实现解耦, 使得两者可以独立的变化
优点:
- 抽象和实现分离. 这是桥梁模式的主要特点, 它完全是为了解决继承的缺点而提出的设计模式. 在该模式下,实现可以不受抽象的约束,不用再绑定在一个固定的抽象层次上
- 优秀的扩充能力.
- 实现细节对客户透明. 客户不用关心细节的实现, 它已经由抽象层通过聚合关系完成了封装
使用场景:
- 不希望或不适用使用继承的场景. 例如继承层次过滤、无法更细化设计颗粒等场景
- 接口或抽象类不稳定的场景.
- 重用性要求较高的场景. 设计的颗粒度越细,则被重用的可能性就越大, 而采用继承则受父类的限制, 不可能出现太细的颗粒度
使用桥梁模式主要考虑如何拆分抽象和实现,并不是一设计继承就要考虑使用该模式. 桥梁模式的意图还是对变化的封装, 尽量把可能变化的因素封装到最细、最小的逻辑单元中,避免风险扩散.因此在进行系统设计时,发现类的继承有N层时,可以考虑使用桥梁模式
角色说明:
Abstraction 抽象化角色: 它的主要职责是定义出该角色的行为, 同时保存一个对实现化角色的引用, 一般是抽象类
Implementor 实现化角色: 接口或抽象类, 定义角色必须的行为和属性
RefinedAbstraction 修正抽象化角色: 它引用实现化角色对抽象化角色进行修正
ConcreteImplementor 具体实现化角色: 它实现接口或抽象类定义的方法和属性
UML类图:
代码实现:
public interface Implementor {
public void doSomething();
public void doAnything();
}
public class ConcreteImplementor1 implements Implementor {
@Override
public void doSomething() {
// TODO Auto-generated method stub
}
@Override
public void doAnything() {
// TODO Auto-generated method stub
}
}
public class ConcreteImplementor2 implements Implementor {
@Override
public void doSomething() {
// TODO Auto-generated method stub
}
@Override
public void doAnything() {
// TODO Auto-generated method stub
}
}
public abstract class Abstraction {
private Implementor imp;
public Abstraction(Implementor imp){
this.imp = imp;
}
public void request(){
this.imp.doSomething();
}
public Implementor getImp(){
return imp;
}
}
public class RefinedAbstraction extends Abstraction {
public RefinedAbstraction(Implementor imp) {
super(imp);
}
@Override
public void request() {
super.request();
super.getImp().doAnything();
}
}
public class Client {
public static void main(String[] args) {
Implementor imp = new ConcreteImplementor1();
Abstraction abs = new RefinedAbstraction(imp);
abs.request();
}
}