Strategy 策略模式

概述

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

适用性

  1. 许多相关的类仅仅是行为有异。“策略”提供了一种用多个行为中的一个行为来配置一个类的方法
  2. 需要使用一个算法的不同变体
  3. 算法使用客户不应该知道的数据。可使用策略模式以避免暴露复杂的、与算法相关的数据结构
  4. 一个类定义了多种行为,并且这些行为在这个类的操作中以多个条件语句的形式出现。 将相关的条件分支移入它们各自的Strategy类中以代替这些条件语句

参与者

  1. Strategy 定义所有支持的算法的公共接口。Context使用这个接口来调用某ConcreteStrategy定义的算法
  2. ConcreteStrategy 以Strategy接口实现某具体算法
  3. Context 用一个ConcreteStrategy对象来配置。 维护一个对Strategy对象的引用。 可定义一个接口来让Stategy访问它的数据

类图

例子

Strategy

public abstract class Strategy {

    public abstract void method();
}

ConcreteStrategy

public class StrategyImplA extends Strategy {

    public void method() {
        System.out.println("这是第一个实现");
    }
}
public class StrategyImplB extends Strategy {

    public void method() {
        System.out.println("这是第二个实现");
    }
}
public class StrategyImplC extends Strategy {

    public void method() {
        System.out.println("这是第三个实现");
    }
}

Context

public class Context {

    Strategy stra;
    
    public Context(Strategy stra) {
        this.stra = stra;
    }
    
    public void doMethod() {
        stra.method();
    }
}

Test

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();
    }
}

结果

这是第一个实现
这是第二个实现
这是第三个实现

商业赞助

532009913@qq.com