[GoF设计模式]Bridge模式和Template模式的C++实现

来源:互联网 发布:vb.net高级开发指南 编辑:程序博客网 时间:2024/05/23 10:50

【Bridge模式】

使用组合的方式将功能的需求的抽象和实现解耦,这样一来抽象和实现可以分别独自的变化。由此解决需求变更可能带来的麻烦,即类的迅速膨胀,如一般的情况下抽象和实现可能需要M*N个类来解决问题,而使用Bridge模式则只需要M+N个类来解决问题。此处的“实现”是指“怎么实现用户的需求”,并且通过组合的方式来实现。此处的实现不是指继承基类,实现基类接口,而是通过组合实现用户的需求。Bridge模式是设计模式中复杂求难理解的模式之一。

【图解】

以中国人吃饭用筷子,美国人吃饭用叉子,当然中国人也可以用叉子吃饭,美国人也可以用筷子吃饭 为例,当然这种情况下用和不用都是定义4个类来实现的,但是当增加到三种情况下时候,运用Bridge模式只定义3+3=6个类,而不用则需要3*3需要9个类。如在加上印度人吃饭用手。简单起见,只列两个。

1

【程序】

 

 

 

 

 

 

 

【输出】

1


 

【Template模式】

对于某一业务逻辑存在不同的细节实现,但总体逻辑框架是相同的。Template模式用于解决这样的问题,strategy模式和他解决的问题类似,但前者是采用集成的方式,封装的是框架,二后者采用的组合的方式,封装的算法。在Template模式中,在模板类(抽象类)的中将原子操作声明为Protected保护类型,而仅提供算法框架的函数供外界调用。

值得说明的是Template模式采用的集成方式是一种反向依赖(DIP,Dependency Inversion Principles)的方式,即父类调用了子类的接口实现(基类调用了派生类的操作)。Template模式的不足是在于其原子操作在各派生类中的细节实现不能被复用,这个问题也是继承自同一个基类说共有的问题。Strategy模式侧重在组合上,将算法封装到一个类中(如:AddOperation),并采用组合的方式解决(实现MathOperation类)。

【图解】

这个例子只做示例用,没写太具体。比如“字符串的模式匹配算法”中有KMP算法,也有前端时间知道的BM算法,这两个算法大体上满足一种逻辑框架,既用模板字符串匹配样本字符串的过程中, 首先匹配样本字符串中的字符串片段,如果没匹配成功,这由连续匹配的字符数,以及当前起始匹配的位置以及模板字符串的长度,计算出在样本字符串中的下一跳批配开始的位置,直到匹配成功。而BM算法是从模板字符串的后面向前面开始比,二KMP则是从前往后。BM和KMP算法在计算下一条位置的实现上也有所不同。以下只是Template模式的示范,并不涉及字符串模式匹配算法的具体实现。

1

 

【程序】

 

 

 

 

【输出】

 

 

3

 

 

 

 

 

 

 

原创粉丝点击