一、概述
定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。
二、适用性
- 许多相关的类仅仅是行为有异。“策略”提供了一种用多个行为中的一个行为来配置一个类的方法。
- 需要使用一个算法的不同变体。
- 算法使用客户不应该知道的数据。可使用策略模式以避免暴露复杂的、与算法相关的数据结构。
- 一个类定义了多种行为,并且这些行为在这个类的操作中以多个条件语句的形式出现。将相关的条件分支移入它们各自的Strategy类中以代替这些条件语句。
三、参与者
- Strategy 定义所有支持的算法的公共接口。Context使用这个接口来调用某ConcreteStrategy定义的算法。
- ConcreteStrategy 以Strategy接口实现某具体算法。
- Context 用一个ConcreteStrategy对象来配置。维护一个对Strategy对象的引用。可定义一个接口来让Stategy访问它的数据。
四、类图
五、示例
- Strategy
package com.lyz.design.strategy; /** * Strategy * @author binghe * */ public abstract class Strategy { public abstract void method(); }
- ConcreteStrategy
StrategyImplA
package com.lyz.design.strategy; /** * ConcreteStrategy * @author binghe * */ public class StrategyImplA extends Strategy { public void method() { System.out.println("这是第一个实现"); } }
StrategyImplB
package com.lyz.design.strategy; /** * ConcreteStrategy * @author binghe * */ public class StrategyImplB extends Strategy { public void method() { System.out.println("这是第二个实现"); } }
StrategyImplC
package com.lyz.design.strategy; /** * ConcreteStrategy * @author binghe * */ public class StrategyImplC extends Strategy { public void method() { System.out.println("这是第三个实现"); } }
- Context
package com.lyz.design.strategy; /** * Context * @author binghe * */ public class Context { Strategy stra; public Context(Strategy stra) { this.stra = stra; } public void doMethod() { stra.method(); } }
- Test
package com.lyz.design.strategy; /** * Test * @author binghe * */ public class Test { public static void main(String[] args) { Context ctx = new Context(new StrategyImplA()); ctx.doMethod(); ctx = new Context(new StrategyImplB()); ctx.doMethod(); ctx = new Context(new StrategyImplC()); ctx.doMethod(); } }
- Result
这是第一个实现 这是第二个实现 这是第三个实现