如何让孩子爱上设计模式 ——14.策略模式(Strategy Pattern)

标签: 设计模式初涉


描述性文字

本节讲解的是行为型设计模式中的第一个模式: 策略模式
这个模式非常简单,也很好理解。
定义一系列的算法,把每个算法封装起来,并使得他们可以相互替换
让算法独立于使用它的客户而变化
一般用来替换if-else,个人感觉是面向过程与面向对象思想的
过渡,这里举个简易计算器的栗子,帮助理解~


普通的if-else/switch计算器

普通的面向过程if-else简易计算器代码如下:

运行结果如下:

这里我们也可以改成switch,代码显得简洁一些,但也是换汤不换药


策略模式实现简易计算器

其实就是把if-else涉及到的算法,策略行为抽取出来,统一的接口,
然后各自实现,比如这里我们把抽取计算的接口,然后继承分别实现
加减乘除:

编写上下文对象负责与具体的策略类交互

客户端调用

输出结果

好了,这就是最简单的策略模式的栗子了,面向对象的if-else到
面向过程的策略模式,算法可以独立于使用它的用户而变化,比如
这里我们加多一个求余也非常简单。


概念相关

定义

定义一系列算法,将每一个算法封装起来,并让它们可以相互替换;
策略模式让算法独立于使用它的客户而变化

三个角色

  • Context: 上下文环境类,持有抽象策略角色的引用
  • Strategy: 抽象策略类,定义一系列抽象的算法策略
  • ConcreteStrategy: 具体策略类,实现具体的算法策略

UML类图

应用场景

  • 1.一个系统需要动态地在几种算法中选择一种的情况
  • 2.系统里面有许多类,它们之间的区别仅在于它们的行为,使用策略模式可以动态
    地让一个对象在许多行为中选择一种行为
  • 3.一个对象有很多的行为,如果不用恰当的模式,这些行为就只好使用多重条件
    选择语句来实现。此时,使用策略模式,把这些行为转移到相应的具体策略类里面,
    就可以避免使用难以维护的多重条件选择语句。
  • 4.不希望客户端知道复杂的、与算法相关的数据结构,在具体策略类中封装算法
    与相关的数据结构,可以提高算法的保密性与安全性。

优缺点

优点:

  • 定义一系列算法实现,实现让这些算法可相互替换
  • 避免多重条件语句
  • 更好的扩展性

缺点:

  • 调用者必须了解每种策略的不同,自行选择使用哪个策略
  • 增加了对象数目,可使用享元模式在一定程度上减少对象数量
  • 只适合扁平的算法结构,在一个策略接口下,运行时只有一个算法被使用,
    这样就限制了算法的使用层级,使用时不能嵌套调用

本节代码

https://github.com/coder-pig/DesignPatternsExample/tree/master/13.Strategy%20Pattern


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 场景问题# 1.1 报价管理## 向客户报价,对于销售部门的人来讲,这是一个非常重大、非常复杂的问题,对不同的...
    七寸知架构阅读 5,133评论 9 62
  • 1 场景问题 1.1 报价管理 向客户报价,对于销售部门的人来讲,这是一个非常重大、非常复杂的问题,对不同的客户要...
    4e70992f13e7阅读 3,128评论 2 16
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,842评论 2 17
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,767评论 18 399
  • 大冰说过,生活就是扯淡,我看着也是,生活像是一场游戏,
    然5阅读 550评论 0 0