今天看了Defonds专栏里面对于策略模式应用场景的描述,感觉比较合适,节选了有关的内容
策略模式的定义
策略模式是应用最普遍的设计模式之一。Gof 把策略模式归类到对象行为型模式,《设计模式:可复用面向对象软件的基础》对策略模式做出了明确的定义:“Define a family of algorithms, encapsulate each one, and make theminterchangeable.Strategy lets the algorithm vary independently fromclients that use it.”,翻译过来就是:“定义了一族算法,将每个算法分别封装起来,并且互相之间可以替换。策略模式可以使算法的变化独立于使用算法的客户”。
why 策略模式?
- 客户端程序直接包含业务算法代码的话会变的复杂,这样会使客户程序庞大且难以维护,尤其是需要支持多种业务算法时。
- 不同的时候需要不同的算法,我们不想支持我们并不使用的业务算法。
- 当业务功能是客户程序的一个难以分割的成分时,增加新的业务算法或改变现有算法将十分困难。
策略模式的使用场合
- 许多相关类仅仅是行为不同。
- 需要使用一个算法的不同实现。
- 算法使用了客户不应该知道的数据。策略模式可以避免暴露复杂的、与算法相关的数据结构。
- 一个类定义了很多行为,而且这些行为在这个类里的操作以多个条件语句的形式出现。策略模式将相关的条件分支移入它们各自的 Strategy 类中以代替这些条件语句。