问题描述
一个类的某个方法,可能存在多种不同的逻辑实现(即算法),并且只有该类的客户才能确定使用哪个算法。一种解决这个问题的办法是:将该方法定义为一个接口(虚函数),创建该类的不同子类,重载该接口来实现不同的算法;客户选择不同的子类来选取不同的算法。但是,仅仅因为一个方法而通过继承创建子类,会产生多个较大的类;也不利于这些算法的重用。策略模式则将该方法封装成一个独立的算法类,由算法类的子类来实现不同的算法;客户依据其上下文为该类配置不同的策略子类来选择不同的算法。
策略模式
如图所示,Strategy类封装了不同的算法实现。Context对象的客户使用不同的ConcreteStrategy类来配置Context对象,Context对象就可以展示不同的行为。独立且小的Strategy类可以方便的被其他类重用。
讨论
策略模式本质上定义了一个函数对象,通过组合一个函数对象,类的客户可以动态配置该函数对象,让类表现出不同的行为。
使用策略模式的客户必须了解并决定算法,前面描述的是方法客户直接配置类的策略对象。间接一点的方法是客户运行时依据上下文向类提供不同的参数,指示类依据一个工厂方法来创建不同的策略类。