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

什么是桥接模式?

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

桥接模式的类图

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

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

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

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

实际问题

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

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

类图如下所示:

这种继承体系存在弊端:

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

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

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

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

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

解决办法:

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

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

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

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

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

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

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

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

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

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

继承的缺点:

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

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

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

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

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏技术之路

sqlserver 的事务和c#的事务

sql的事务 1 sql 2 create database model 3 go 4 use model 5 go 6 create table ...

1929
来自专栏跟着阿笨一起玩NET

使用延迟的FileSystemWatcher来避免重复触发事件

  程序里需要监视某个目录下的文件变化情况: 一旦目录中出现新文件或者旧的文件被覆盖,程序需要读取文件内容并进行处理;但在实际处理中发现当一个文件产生变化时,C...

912
来自专栏跟着阿笨一起玩NET

从sql server 中读取二进制图片

401
来自专栏码匠的流水账

zuul自定义SimpleHostRoutingFilter

zuul的SimpleHostRoutingFilter主要用来转发不走eureka的proxy,里头是使用httpclient来转发请求的,但是有时候我们需要...

1302
来自专栏xingoo, 一个梦想做发明家的程序员

【插件开发】—— 6 SWT 复杂控件使用以及布局

前文回顾: 1 插件学习篇 2 简单的建立插件工程以及模型文件分析 3 利用扩展点,开发透视图 4 SWT编程须知 5 SWT简单控件的使用与布局搭...

2349
来自专栏张善友的专栏

通过SmtpClient发送Exchange会议邮件

看到C#中调用Outlook API 发起会议 ,这个完全可以用SMTP方式实现的,下面我的项目中使用的代码: 对于.NET而言,从2.0开始,发邮件已经是一件...

1949
来自专栏Golang语言社区

GO语言 TCP传输实例

package main import ( "net" "fmt" ) var ( maxRead = 1100 msgStop = []byt...

3406
来自专栏木宛城主

曾今的代码系列——自己的分页控件+存储过程实现分页

项目里面的测试代码,仅供参考 LoginByAjax <title>Ajax登陆</title> <script src="Scripts/c...

1865
来自专栏hbbliyong

socket 通信 多线程调用窗体(委托)的几个知识点,记录在案,以备查阅

1.socket 通信传输汉字的方法:Encoding.GetEncoding("GB2312").GetString(Receivebyte) 发送接收都这样...

2737
来自专栏c#开发者

xmldocument内嵌入另一个xmldocument,xmlnode的方法

string xmlstr1 = @"<root><head>myHead</head><body></body></root>"; s...

2725

扫码关注云+社区