目录
简介
定义
特点
结构
示例
1. 新建 Brand.interface 接口类,定义不同品牌手机共有的基本功能
2. 新建 Xiaomi.class 类,实现 Brand.interface 接口,实现具体功能
3. 新建 Vivo.class 类,实现 Brand.interface 接口,实现具体功能
4. 新建 Phone.class 类,这是桥接类,定义手机操作行为,不限手机品牌
5. 新建 FolderPhone.class 折叠样式手机类,继承 Phone.class,获得手机的功能;这一步就把手机样式和功能桥接起来了
6. 添加测试类,测试不同品牌折叠样式手机的功能
简介
在现实生活中,某些类具有两个或多个维度的变化,如图形既可按形状分,又可按颜色分;如何设计类似于 Photoshop 这样的软件,能画不同形状和不同颜色的图形呢?如果用继承方式,m 种形状和 n 种颜色的图形就有 m×n 种,不但对应的子类很多,而且扩展困难;桥接模式就是为了解决这样的问题
定义
桥接模式是将抽象部分与它的实现部分分离,使它们都可以独立地变化;它是一种对象结构型模式,又称为柄体(Handle and Body)模式或接口(interface)模式
特点
桥接模式是指将实现与抽象放在两个不同的类层次中,使两个层次可以独立改变;
桥接模式是一种结构型设计模式
桥接模式基于类的最小设计原则,通过使用封装、聚合及继承等行为让不同的类承担
不同的职责;它的特点是把抽象的与行为分离开来,从而可以保持各部分的独立性以及对他们的功能扩展
结构
1)抽象化(Abstraction)角色:定义抽象类,并包含一个对实现化对象的引用
2)扩展抽象化(Refined Abstraction)角色:是抽象化角色的子类,实现父类中的业务方法,并通过组合关系调用实现化角色中的业务方法
3)实现化(Implementor)角色:定义实现化角色的接口,供扩展抽象化角色调用
4)具体实现化(Concrete Implementor)角色:给出实现化角色接口的具体实现
示例
以手机为例,手机有多个品牌(小米、vivo ...),有多种样式(折叠、直板、滑盖 ...),有多种功能(开机、关机、打电话 ...),使用桥接模式把手机品牌和样式分开实现然后再关联起来
示例代码
1. 新建 Brand.interface 接口类,定义不同品牌手机共有的基本功能
/**
* 手机品牌, 任何品牌的手机都具有
* 开机, 关机, 打电话的功能
*/
public interface Brand {
// 开机
void open();
// 关机
void close();
// 打电话
void call();
}
2. 新建 Xiaomi.class 类,实现 Brand.interface 接口,实现具体功能
/**
* 小米手机类, 实现具体功能
*/
public class Xiaomi implements Brand {
@Override
public void open() {
System.out.println("小米手机开机");
}
@Override
public void close() {
System.out.println("小米手机关机");
}
@Override
public void call() {
System.out.println("小米手机打电话");
}
}
3. 新建 Vivo.class 类,实现 Brand.interface 接口,实现具体功能
/**
* vivo 手机类, 实现具体功能
*/
public class Vivo implements Brand {
@Override
public void open() {
System.out.println("vivo手机开机");
}
@Override
public void close() {
System.out.println("vivo手机开机");
}
@Override
public void call() {
System.out.println("vivo手机打电话");
}
}
4. 新建 Phone.class 类,这是桥接类,定义手机操作行为,不限手机品牌
/**
* 桥接类, 定义手机操作行为, 不局限具体手机品牌
*/
public abstract class Phone {
// 关联手机类型
private Brand brand;
public Phone(Brand brand) {
this.brand = brand;
}
// 开机
protected void open() {
this.brand.open();
}
// 关机
protected void close() {
this.brand.close();
}
// 打电话
protected void call() {
this.brand.call();
}
}
5. 新建 FolderPhone.class 折叠样式手机类,继承 Phone.class,获得手机的功能;这一步就把手机样式和功能桥接起来了
/**
* 手机样式:折叠手机
*/
public class FolderPhone extends Phone {
public FolderPhone(Brand brand) {
super(brand);
}
// 开机
public void open() {
super.open();
System.out.println("折叠样式手机开机");
}
// 关机
public void close() {
super.close();
System.out.println("折叠样式手机关机");
}
// 打电话
public void call() {
super.call();
System.out.println("折叠样式手机打电话");
}
}
6. 添加测试类,测试不同品牌折叠样式手机的功能
/**
* 测试类
*/
public class Test {
public static void main(String[] args) {
Phone xiaomi = new FolderPhone(new Xiaomi());
xiaomi.open();
xiaomi.close();
xiaomi.call();
Phone vivo = new FolderPhone(new Vivo());
vivo.open();
vivo.close();
vivo.call();
}
}
观察上述代码,这种设计模式带来的最大好处就是:当我们需要扩展更多样式的手机或者更多品牌的手机的时候,不需要动原来的代码,只需要继续添加样式或品牌手机类即可