7.桥接模式
7.1 介绍
- 将抽象部分与它的实现部分分离,使他们都可以独立地变化。它是一种对象结构型模式,又称为柄体(handle and body)模式或接口(interface)模式
- 适配器模式是对已有的接口进行适配使二者兼容,通过别的接口完成自己完不成的功能;桥接模式是是对抽象与实现的分离,将变化的维度拆分再进行组合和组合,让代码更加有结构性。
- 适配器模式解决兼容问题,桥接模式解决功能扩展问题
7.2 举例理解
//品牌
public interface Brand {
void brandInfo();
}
- 品牌接口实现
//中石油
public class PetroChina implements Brand {
@Override
public void brandInfo() {
System.out.println("中石油");
}
}
//中石化
public class Sinopec implements Brand {
@Override
public void brandInfo() {
System.out.println("中石化");
}
}
//延长
public class Extend implements Brand {
@Override
public void brandInfo() {
System.out.println("延长");
}
}
- 石油抽象类,组合关系—桥
//石油抽象类--自带品牌---桥
public abstract class Oil {
//石油出产自带品牌
//组合关系--------桥
protected Brand brand;
public Oil(Brand brand) {
this.brand = brand;
}
public void oilInfo(){
brand.brandInfo(); //自带品牌,品牌的方法
};
}
- 子类
//煤油
public class Kerosene extends Oil{
public Kerosene(Brand brand) {
super(brand);
}
@Override
public void oilInfo() {
super.oilInfo();
System.out.println("煤油");
}
}
//汽油
public class Gasoline extends Oil{
public Gasoline(Brand brand) {
super(brand);
}
@Override
public void oilInfo() {
super.oilInfo();
System.out.println("汽油");
}
}
//柴油
public class DieselOil extends Oil{
public DieselOil(Brand brand) {
super(brand);
}
@Override
public void oilInfo() {
super.oilInfo();
System.out.println("柴油");
}
}
- 测试:组装思想
@Test
public void testBridge(){
//中石油+汽油
PetroChina petroChina = new PetroChina();
Oil gasoline = new Gasoline(petroChina);
gasoline.oilInfo();
//延长+煤油
Extend extendoil = new Extend();
Oil keroline = new Kerosene(extendoil);
keroline.oilInfo();
}
/*中石油
汽油
延长
煤油*/
7.3 优缺点
- 优点:
桥接模式偶尔类似于多继承方案,但是多继承方案违背了类的单一职责原则,复用性比较差,类的个数也非常多,桥接模式是比多继承方案更好的解决方法。极大的减少了子类的个数,降低管理和维护成本
桥接模式提高了系统的可扩展性,在两个变化维度中任意扩展一个维度,都不需要改原有的系统,如已做桥,将两个变量连起来
- 缺点:
桥接模式会增加系统的理解和设计难度,由于聚合关联关系建立在抽象层,要求开发者对抽象进行设计编程
桥接模式要求正确识别系统中两个独立变化的维度,因此器使用范围具有一定的局限性。
7.4 应用实践
系统需要在构建抽象化和具体化角色之间有更多的灵活性,避免在两个层次间建立继承关系,通过此模式使它们在抽象层次建立一个关联关系。
抽象化角色和实现化角色可以用继承的方式独立扩展互不影响,在运行时将一个抽象化子类的对象和一个实现化子类进行组合
即系统需要对抽象化角色和实现化角色进行动态耦合
一个类存在两个独立变化的维度,且这俩个维度都需要进行扩展
虽然在系统中使用继承没问题,但由于抽象化角色和实现化角色需要独立化,设计要求需要独立管理这两者。对于不希望使用继承或多层次继承导致类的个数急剧增加的系统,适用于此模式
- 场景:
java语言通过JVM实现了跨平台(多种设计模式如:适配器模式+桥接模式)
GUI编程中AWT中peer架构
jdbc驱动程序
- 模式之间相互转换:适配器模式<==>桥接模式(两个因素适配联系起来)
####本专栏下一篇:设计模式之代理模式、静态代理模式
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/123928.html