java 策略模式

策略模式——Strategy (政策模式——Policy)的意图:

定义一系列的算法,把它们一个个封装起来,并且使他们可以相互替换。

动机:

有许多算法可以对一个正文流进行分析,将这些算法硬编码进它们的类中是不可取的,其原因如下:
1.需要换行功能的客户程序如果直接包含换行算法的话就会变得复杂,这使得客户程序庞大而且难以维护,尤其是需要支持多种换行算法的时间问题会更加严重。
2.不同的时候需要不同的算法,我们不想支持我们并不使用的换行算法。
3.当换行功能是客户程序的一个难以分割的成分时,增加新的换行算法或者改变现有的算法会非常困难。

为此我们可以定义一些类来封装不同的换行算法,从而避免这些问题。一个以这些方法封装的算法称为一个策略(strategy)。
策略模式UML
策略模式的参与者:
1.Strategy(策略)
——定义的所有支持的算法的公共接口。Context使用这个接口来调用某个ConcreteStrategy定义的算法。
2.ConcreteStrategy(具体策略)
——以Strategy接口实现某具体算法。
3.Context(上下文)
——用一个ConcreteStrategy对象来配置。
——维护一个队Strategy对象的引用。
——可以定义一个接口来让Strategy访问它的数据。

适用性:

当存在以下情况的时候应当使用Strategy模式
1.许多相关类仅仅是行为有异。“策略”提供了一种用多个行为中一个行为来配置一个类的方法。
2.需要使用一个算法的不同变体。例如,你可能定义一些反映不同空间/时间的权衡的算法,当这些变体实现为一个算法的层次时,可以使用策略模式。
3.算法的使用客户不应该知道数据,可以使用策略模式以避免暴露复杂、与算法相关的数据结构。
4.一个类定义了多种行为,并且这些行为在这个类中以多个条件语句形式出现。将相关的条件分支移入它们各自的Strategy类中以替换这些条件语句。
OK现在来看看具体的代码:

class Context {
    private Strategy strategy;
    public Context(Strategy strategy){
        this.strategy = strategy;
    }
    public void contextInterface(){
        strategy.strategyInterface();
    }
}
interface Strategy {
    public void strategyInterface();
}

class ConcreteStrategyA implements Strategy{

    @Override
    public void strategyInterface() {
        System.out.println("this is strategyA");
    }

}
class ConcreteStrategyB implements Strategy{

    @Override
    public void strategyInterface() {
        System.out.println("this is strategyB");
    }
}
class ConcreteStrategyC implements Strategy{
    @Override
    public void strategyInterface() {
        System.out.println("this is strategyC");
    }
}
public class StrategyMethod {

    public static void main(String[] args) {
         Context context=new Context(new ConcreteStrategyC());
         context.contextInterface();
    }

}
策略模式是一种行为设计模式,它允许在运行时选择算法的行为。在策略模式中,我们创建表示各种策略的对象和一个上下文对象,该对象可以根据其策略对象的不同行为而更改其执行算法。 以下是Java策略模式的示例代码: 首先,我们定义一个策略接口,该接口定义了一个方法calculate(),该方法将由具体策略类实现: ```java public interface Strategy { public int calculate(int num1, int num2); } ``` 然后,我们实现两个具体策略类,它们实现了策略接口并提供了自己的实现: ```java public class AddStrategy implements Strategy { public int calculate(int num1, int num2) { return num1 + num2; } } public class SubtractStrategy implements Strategy { public int calculate(int num1, int num2) { return num1 - num2; } } ``` 接下来,我们定义一个上下文类,该类将使用策略接口来执行算法: ```java public class Context { private Strategy strategy; public Context(Strategy strategy) { this.strategy = strategy; } public int executeStrategy(int num1, int num2) { return strategy.calculate(num1, num2); } } ``` 最后,我们可以在客户端代码中使用上下文对象来执行算法: ```java public class Client { public static void main(String[] args) { Context context = new Context(new AddStrategy()); System.out.println("10 + 5 = " + context.executeStrategy(10, 5)); context = new Context(new SubtractStrategy()); System.out.println("10 - 5 = " + context.executeStrategy(10, 5)); } } ``` 输出结果为: ``` 10 + 5 = 15 10 - 5 = 5 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值