内容简介:我在某种程度上理解桥梁模式.我理解接口和实现的分离.它使用类似插件的实现者类,它保存派生类实现的实际逻辑.但有人可以解释它如何允许接口和派生独立发展?如果我想在接口中添加一个新方法,则必须在派生类中实现它,这将修改它.其次,必须修改客户端代码以在需要新对象时设置新的实现者.
我在某种程度上理解桥梁模式.我理解接口和实现的分离.它使用类似插件的实现者类,它保存派生类实现的实际逻辑.
但有人可以解释它如何允许接口和派生独立发展?如果我想在接口中添加一个新方法,则必须在派生类中实现它,这将修改它.
其次,必须修改客户端代码以在需要新对象时设置新的实现者.
是的,Bridge模式的目的是将抽象(即接口)与实现分离,让它们独立变化.在实践中,想法是使用两个单独的层次结构而不是经典的单个层次结构.
我们举个例子吧.假设您有一个Window抽象,并且您需要为每个支持的平台创建一个专门用于Window的IconWindow子类.
使用单个层次结构,您将获得:
Window
|--------------...
IconWindow
|
-----------------------------------------------...
| | |
XIconWindow MSIconWindow OSXIconWindow
这种结构非常不方便,因为:
>如果要添加专门用于Window的新子类(例如,BitmapWindow),则必须为每个受支持的平台(即本示例中的三个子类)创建子类.
>如果要添加支持的平台,则必须为每个现有的特化添加新的子类.
因此,最好通过以下方式解耦两个层次结构:
imp
Window--------------------------> WindowImp
| |
-----------.... ---------------------------------
| | | |
IconWindow XWindowImp MSWindowImp OSXWindowImp
Window和WindowImp是接口.
IconWindow使用Window提供的方法.反过来,窗口调用imp上的相关方法.
Window和WindowImp之间的关系称为Bridge.
例:
IconWindow :: DrawBorder()使用Window :: DrawRect(),它调用imp-> DevDrawLine(),它在WindowImp中声明并在具体子类中定义(例如,在类XWindowImp中).
我的建议是阅读包含上述示例的书:设计模式 – 可重用面向对象软件的元素“( http://en.wikipedia.org/wiki/Design_Patterns ).
翻译自:https://stackoverflow.com/questions/17015997/bridge-pattern-understanding
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 设计模式——订阅模式(观察者模式)
- 设计模式-简单工厂、工厂方法模式、抽象工厂模式
- java23种设计模式-门面模式(外观模式)
- 设计模式-享元设计模式
- Java 设计模式之工厂方法模式与抽象工厂模式
- JAVA设计模式之模板方法模式和建造者模式
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
白话机器学习算法
[新加坡] 黄莉婷、[新加坡] 苏川集 / 武传海 / 人民邮电出版社 / 2019-2 / 49.00元
与使用数学语言或计算机编程语言讲解算法的书不同,本书另辟蹊径,用通俗易懂的人类语言以及大量有趣的示例和插图讲解10多种前沿的机器学习算法。内容涵盖k均值聚类、主成分分析、关联规则、社会网络分析等无监督学习算法,以及回归分析、k最近邻、支持向量机、决策树、随机森林、神经网络等监督学习算法,并概述强化学习算法的思想。任何对机器学习和数据科学怀有好奇心的人都可以通过本书构建知识体系。一起来看看 《白话机器学习算法》 这本书的介绍吧!