美文网首页
模板方法和策略模式区别【GeekBand】

模板方法和策略模式区别【GeekBand】

作者: clamxyz | 来源:发表于2016-07-12 23:01 被阅读0次

在做这周设计模式的作业时对实现“FileSplitter支持多种文件分割算法”应该模板方法模式还是策略模式纠结一下,通过对查阅相关资料得到了解答,遂记录于此。
作业题目[1]:

考虑一个文件分割器的设计。MainForm为界面类,收集用户输入的文件路径和分割数量。FileSpliter为实现文件分割的类型,其中Split()实现文件分割算法。1.要求为Split()支持多种文件分割算法(至少三种),在MainForm中灵活切换多种算法。2.在Split()分割过程中,实现对进度条的实时通知,即对ProgressBar赋值。3.使用松耦合面向对象设计方法和思想,无需编写具体算法实现,可使用伪码表示设计。

在实现Split的过程,发现模板方法和策略模式都可以满足题目的要求。模板方法以FileSplitter为基类,在Split实现文件分割的大流程和对进度条的实时通知,将真正实现切割的代码doSplit声明为保护方法,让子类覆盖。子类通过覆盖父类的doSplit来实现算法定制。为达到在MainForm自由切换算法的目的,可以使用简单工厂模式来自由生产FileSplitter实例。类结构图如下:


图1模板方法结构图

同样该问题也可以使用策略模式来解决。策略模式首先声明一个ISplitStragy接口,该方法包含了一个实现算法分割的接口doSplit。各个文件分割策略都实现ISplitStragy接口,然后FileSplitter包含一个ISplitStragy对象并在Split()函数中调用该策略。同样,为了实现在MainForm中自由的切换算法,可以使用简单工厂模式来自由生产FileSplitter实例。类结构图如下:


图2策略模式结构图

通过上述的讲解,我们发现该题完全可以通过模板方法/策略模式来实现,而且也看不出谁优谁劣。那么这两种方法是否等同了吗?显然不是。
首先,我们来看下这两种模式的意图。
策略模式[2]

定义一系列的算法,把它们一个个封装起来, 使它们可相互替换。本模式使得算法可独
立于使用它的客户而变化。

模板方法[2]

定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。TemplateMethod使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。

从意图上来看,两者都在试图解决算法多样性对代码结构的冲击。只是,策略模式通过将算法封装成类,通过组合使用这些类。而模式方法则将算法的可变部分封装成Hook,由子类定制。
从定义上来看,模式方法更加侧重于业务流程相对复杂且稳定,而其中的某些步骤(局部变化)变化相对剧烈的场景。而策略模式则是偏重于算法本身(整个算法)就变化相对距离的情形。因此,当使用场景中业务流程相对简单且稳定的情况,使用策略模式和模板方法都是可以得,但是更推荐用模板方法(模板方法更灵活)。
综上:模板方法和策略模式都是解决算法多样性对代码结构冲击的问题。模板方法使用与业务场景相对复杂且稳定的情况,策略模式使用与算法相对多样灵活的场景。当业务相对简单时,策略模式和模板方法几乎等效,但是推荐使用策略模式。
参考资料:
[1]设计模式第一周作业 http://mooc.study.163.com/learn/GeekBand-1000113005?tid=2001225007#/learn/hw?id=2001449004
[2]设计模式 GoF

相关文章

  • 模板方法和策略模式区别【GeekBand】

    在做这周设计模式的作业时对实现“FileSplitter支持多种文件分割算法”应该模板方法模式还是策略模式纠结一下...

  • 设计模式--策略模式

    目录 本文的结构如下: 引言 什么是策略模式 模式的结构 典型代码 代码示例 策略模式和模板方法模式的区别 优点和...

  • java8 in action:第8章学习,Lambda重构面向

    匿名类和Lamda中的this区别### 策略模式### 模板方法### 观察者模式### 责任链模式### La...

  • 各种设计模式总结和对比

    模板方法模式和策略模式 1、模板方法和策略模式都有封装算法。2、策略模式是使不同算法可以相互替换,且不影响客户端应...

  • 设计模式

    策略模式 接口 模板方法模式 抽象类 代理模式 接口

  • 五、行为型模式

    用来对类或对象怎样交互和怎样分配职责进行描述 1.模板方法2.命令模式3.策略模式4.观察者模式 1.模板方法 1...

  • spring框架中的设计模式二

    在这篇文章中,介绍4种设计模式。结构型设计模式:代理和复合模式。行为型设计模式:策略和模板方法模式。 代理模式 面...

  • 常见六种设计模式.2018-08-01

    单例模式 工厂模式 策略模式 观察者模式 迭代器模式 模板方法模式 https://www.jianshu.com...

  • JS 设计模式

    工厂模式 单体模式 模块模式 代理模式 职责链模式 命令模式 模板方法模式 策略模式 发布-订阅模式 中介者模式 ...

  • 设计模式《策略模式》

    引言   继续上一节的模板方法模式,这节我们来说说策略模式。 示例地址   Demo 先看类图 看看策略模式的定义...

网友评论

      本文标题:模板方法和策略模式区别【GeekBand】

      本文链接:https://www.haomeiwen.com/subject/rpssjttx.html