一、意图
将抽象部分与它的实现部分分离,使他们都可以独立的变化。
二、适用性
以下一些情况使用Bridge模式
你不希望在抽象和它的实现部分之间有一个固定的绑定关系。例如这种情况可能因为,在程序运行时刻实现部分应可以被选择或者切换。
类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充。这时Bridge模式使你可以对不同的抽象接口和实现部分进行组合,并分别对他们进行扩充。
对一个抽象的实现部分的修改应对客户不产生影响,即客户代码不必重新编译。
(C++)你想对客户完全隐藏抽象的实现部分。在C++中,类的表示在类接口中是可见的。
三、结构
四、代码
1
2
3
4
5
6
|
public interface Implementor { /** * 实现抽象部分的具体方法 */ public void operationImpl(); } |
1
2
3
4
5
6
|
public class ConcreteImplementorA implements Implementor { @Override public void operationImpl() { System.out.println( "ConcreteImplementorA" ); } } |
1
2
3
4
5
6
|
public class ConcreteImplementorB implements Implementor { @Override public void operationImpl() { System.out.println( "ConcreteImplementorB" ); } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
public abstract class Abstraction { private Implementor mImplementor; /** * 通过实现部分对象的引用构造抽象部分的对象 * * @param implementor 实现部分对象的引用 */ public Abstraction(Implementor implementor){ mImplementor = implementor; } public void operation(){ mImplementor.operationImpl(); } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
public class RefinedAbstraction extends Abstraction { /** * 通过实现部分对象的引用构造抽象部分的对象 * * @param implementor 实现部分对象的引用 */ public RefinedAbstraction(Implementor implementor) { super (implementor); } public void refinedOperation(){ //对 Abstraction中的方法进行扩展。 System.out.println( "refinedOperation" ); operation(); } } |
1
2
3
4
5
6
7
|
public class Client { public static void main(String[] args){ Abstraction abstraction = new RefinedAbstraction( new ConcreteImplementorA()); abstraction.operation(); } } |
如有疑问请留言或者到本站这区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/a992036795/article/details/52756256