桥接模式是一个非常有用的模式,也是比较复杂的一个模式,熟悉这个模式,对于理解面向对象的设计原则,包括开放封闭原则及组合/聚合复用原则(CARP)都很有帮助,理解好这两个原则,有助于形成正确的设计思想和培养良好的设计风格。
1、意图
将抽象部分与实现部分分离,使得两个部分可以独立变化
2、角色及其职责
- 抽象化(Abstraction)角色:抽象画给出的定义,并保存一个对实现化对象的引用。
- 修正抽象化(Refined Abstraction)角色:扩展抽象化角色,改变和修正父类对抽象化的定义。
- 实现化(Implementor)角色:给出实现化角色的接口,但不给出具体的实现。必须指出,这个接口不一定和抽象化角色的接口定义相同,实际上,这两个接口可以非常不一样。实现化角色应当只给出底层操作,而抽象化角色应当只给出基于底层操作的更高一层的操作。
- 具体实现化(Concrete Implementor)角色:给出实现化角色接口的具体实现
桥接模式解决手机操作问题:
改进为:
代码:
package com.ag.structure;
public class BridgeMode {
public static void main(String[] args) {
Phone foldedPhone = new FoldedPhone(new Vivo());
foldedPhone.Open();
foldedPhone.call();
foldedPhone.close();
}
}
interface Brand{
void open();
void call();
void close();
}
class Vivo implements Brand{
public void open() {
System.out.println("Vivo手机打开");
}
public void call() {
System.out.println("Vivo手机打电话");
}
public void close() {
System.out.println("Vivo手机关闭");
}
}
class Xiaomi implements Brand{
public void open() {
System.out.println("Xiaomi手机打开");
}
public void call() {
System.out.println("Xiaomi手机打电话");
}
public void close() {
System.out.println("Xiaomi手机关闭");
}
}
abstract class Phone{
protected Brand brand;
Phone(Brand brand){
this.brand = brand;
}
public void Open(){
brand.open();
}
public void call(){
brand.call();
}
public void close(){
brand.close();
}
}
class FoldedPhone extends Phone{
FoldedPhone(Brand brand) {
super(brand);
}
public void Open(){
brand.open();
System.out.println("折叠式手机");
}
public void call(){
brand.call();
System.out.println("折叠式手机");
}
public void close(){
brand.close();
System.out.println("折叠式手机");
}
}
class UpRightPhone extends Phone{
UpRightPhone(Brand brand) {
super(brand);
}
public void Open(){
brand.open();
System.out.println("折叠式手机");
}
public void call(){
brand.call();
System.out.println("折叠式手机");
}
public void close(){
brand.close();
System.out.println("折叠式手机");
}
}
3、优势和缺陷
桥接模式可以从接口分离实现功能,使得设计更具有扩展性,这样,客户调用方法时根本不需要知道实现的细节。桥接模式减少了子类,使代码变得更清洁,生成的程序更小了,但是,桥接模式的缺陷是抽象类与实现类的双向连接变得运行速度变慢了
4、适用场景
- 避免抽象方法和其实现方法绑定在一起
- 抽象接口和实现都需要扩展出子类以备使用
- 变动实现的方法根本不会影响客户程序调用的部分