设计模式之策略模式(六)

策略模式是一种常用的设计模式,主要用于将算法的实现和调用者分离,从而使算法的实现可以独立于调用者而变化。其基本思想是定义一系列算法,将它们分别封装成策略类,让这些策略类可以相互替换,从而使得算法的变化可以独立于使用算法的客户端代码。

下面是一个使用Java语言实现策略模式的例子:

首先,定义一个算法接口:

public interface Strategy {
    int calculate(int a, int b);
}

然后,我们可以实现这个接口,定义一些具体的算法:


public class AddStrategy implements Strategy {
   @Override
   public int calculate(int a, int b) {
      return a + b;
   }
}

public class SubStrategy implements Strategy {
   @Override
   public int calculate(int a, int b) {
      return a - b;
   }
}

public class MulStrategy implements Strategy {
   @Override
   public int calculate(int a, int b) {
      return a * b;
   }
}

public class DivStrategy implements Strategy {
   @Override
   public int calculate(int a, int b) {
      return a / b;
   }
}

接下来,在客户端代码中,我们可以根据需要选择不同的算法:

public class Context {
   private Strategy strategy;

   public Context(Strategy strategy){
      this.strategy = strategy;
   }

   public int executeStrategy(int a, int b){
      return strategy.calculate(a, b);
   }
}


```

最后,我们可以在客户端代码中使用这个Context类来执行具体的算法:

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 SubStrategy());
    System.out.println("10 - 5 = " + context.executeStrategy(10, 5));
  
    context = new Context(new MulStrategy());
    System.out.println("10 * 5 = " + context.executeStrategy(10, 5));
  
    context = new Context(new DivStrategy());
    System.out.println("10 / 5 = " + context.executeStrategy(10, 5));
}

在这个例子中,我们使用了策略模式来封装了不同的算法,并且使用Context类将算法的执行和客户端代码分离开来。这种做法使得我们可以在不修改客户端代码的情况下,动态地选择不同的算法实现。

这个例子中的使用场景是,当我们需要动态地选择不同的算法实现时,可以使用策略模式来实现。此外,它还可以用于封装一系列的业务规则,从而更好的保证代码的可扩展性和可维护性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值