三分钟理解“桥接模式”——设计模式轻松掌握

什么是桥接模式?

将两个继承体系使用聚合/组合连接在一起,这就是桥接模式。

桥接模式的类图

桥接模式中,最大的特色就中两个继承体系中间的那座桥(聚合/组合)。

桥接模式中有两个继承体系,分别称为“抽象”和“实现”;

抽象类中持有实现类的引用,并且含有set函数用于给用户设置这个抽象类的实现;

当给抽象类的对象设置完实现类对象之后,用户就可以通过抽象类的对象访问实现类对象中的函数及变量了。

实际问题

请用继承体系表示以下事例:

老式手机由于操作系统不一致,因此不同厂家在生产完手机之后还得为该手机定制软件,也就是每个厂家生产的软件不能跨平台使用。

类图如下所示:

这种继承体系存在弊端:

此时如果要增加一种手机品牌,就还要为该品牌增加所有的软件类;

如果还要增加一种软件,就需要为所有品牌的手机增加新的软件类;

也就是说,目前这个继承体系的类分为两种类型,一种是手机品牌类,一种是手机软件类;不管增加哪种类型的类,都会导致要同时增加多个类,这样下去会导致继承体系过于庞大。

出现这种弊端的根本原因如下:

多种类别的类都存在于一个继承体系中,这样就会导致当增加一种功能时会相应增加多个类,而且有许多类之间功能大都相似。

解决办法:

将一个继承体系中的多种类型的类分成单独的继承体系,然后使用聚合/组合将这两个继承体系连接在一起。

这样当需要增加类时,由于新的类属于一个单独的继承体系,因此只需要在某一个继承体系中增加一个子类即可,从而避免了继承体系过于庞大的问题。

而这种将一个继承体系分成两个用组合/聚合方式连接的继承体系的方式就称为“合成/聚合复用原则”。

此时,如果需要增加一个类,只需要在一个继承体系中增加一个子类即可,无需增加好多类,从而继承体系不会异常庞大。

知识点扫盲——————————————————————————

什么是“合成/聚合复用原则”?

在程序设计时,应尽量使用合成/聚合,而尽量避免使用继承!

什么是“合成”与“聚合”?

聚合:在类A的成员变量中含有类B的对象的引用,但类B的成员变量中没有类A的对象的引用,则A和B的关系称为聚合,聚合是一种“弱拥有”的关系。

合成:在类A的成员变量中含有类B的对象的引用,但类B的成员变量中没有类A的对象的引用,并且A、B对象的生命周期必须一致,也就是类A的构造函数中要为成员变量B创建对象。因此,合成是一种强引用关系。

继承的缺点:

由于对象的继承关系是在编译时就定义好了,因此无法在运行时改变子类中从父类继承过来的实现。

并且子类的实现与父类有非常紧密的依赖关系,以至于父类实现中的任何变化必然会导致子类变化的发生。

当你需要复用子类时,如果继承下来的实现不适合解决新的问题,则父类必须重写或被其他更适合的类替换。

这种依赖关系限制了灵活性,并最终限制了复用性。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏nummy

简单工厂模式

简单工厂模式又叫静态工厂方法模式,工厂模式家族中最简单的一种模式。这个模式的基本工作方式: 通过一个工厂来决定创建哪种具体的产品实例。

471
来自专栏用户2442861的专栏

java IO流之一 IO流介绍

     IO流指 的是输入输出流,用来处理设备上的数据。这里的设备指硬盘,内存,键盘录入,网络传输等。

563
来自专栏Phoenix的Android之旅

这是你在苦苦找寻的资料吗

趁着Java10发布的时候,小编将整理的有用的学习资料分享给大家,希望能有帮助。 下面说说刚发布的Java10.

632
来自专栏Java学习网

Java中提高代码复用性的方法及规范总结

一个好的程序员一定是用最少的代码实现最多的功能,代码复用是程序员所追求和期望的,这也是Java语言所提倡的;根据以往开发经验整理了一些能够提高代码复用性方法和规...

2907
来自专栏Java技术栈

Java 编程中关于异常处理的 10 个最佳实践

异常处理是Java 开发中的一个重要部分。它是关乎每个应用的一个非功能性需求,是为了处理任何错误状况,比如资源不可访问,非法输入,空输入等等。Java提供了...

1364
来自专栏iKcamp

翻译连载 |《你不知道的JS》姊妹篇 |《JavaScript 轻量级函数式编程》- 第 6 章:值的不可变性

原文地址:Functional-Light-JS 原文作者:Kyle Simpson-《You-Dont-Know-JS》作者 第 6 章:值的不可变性 在第 ...

1885
来自专栏阿杜的世界

如何设计接口的测试用例边界值测试组合条件测试

今天在帮同事review代码的时候,发现他的代码遗漏了一些场景的处理,就顺便跟他多聊了些为对这个话题的看法。

632
来自专栏怀英的自我修炼

Java漫谈6

今天这篇想聊聊数组。 在聊数组之前先聊个别的,如果想在Java中实现一个 数字-月份 转换,那我该怎么做呢?就比如数字1代表了一月份,数字2代表了二月份…数字1...

3429
来自专栏小L的魔法馆

新疆大学ACM-ICPC程序设计竞赛五月月赛(同步赛)--B-杨老师的游戏

3939
来自专栏数据结构与算法

UOJ#52. 【UR #4】元旦激光炮(交互)

一种很显然的$log^2n$的做法:首先在$a$中二分,然后再$b,c$中二分。这样可以得到$60$分的好成绩。

522

扫码关注云+社区