0
点赞
收藏
分享

微信扫一扫

Java策略模式(Strategy)


文章目录

  • ​​策略模式(Strategy)​​
  • ​​一.不使用策略模式​​
  • ​​二.使用策略模式​​
  • ​​1.案例类图​​
  • ​​2.案例实现​​
  • ​​3.总结​​
  • ​​4.开发中的使用场景​​


策略模式(Strategy)

一.不使用策略模式

使用场景
某个市场人员接到单后的报价策略(CRM系统中常见问题)。报价策略很复杂,可以简单作如下分类:

  1. 普通客户小批量报价
  2. 普通客户大批量报价
  3. 老客户小批量报价
  4. 老客户大批量报价

具体选用哪个报价策略,这需要根据实际情况来确定。这时候,如果我们用普通的方式来实现如下

public double getPrice(String type, double price) {
if (type.equals("普通客户小批量")) {
System.out.println("不打折,原价");
return price;
} else if (type.equals("普通客户大批量")) {
System.out.println("打九折");
return price * 0.9;
} else if (type.equals("老客户小批量")) {
System.out.println("打八五折");
return price * 0.85;
} else if (type.equals("老客户大批量")) {
System.out.println("打八折");
return price * 0.8;
}
return price;
}

  这种通过条件判断的方式来实现比较符合普通程序员的思维习惯,但是算法比较复杂时,整个条件控制代码会变得很长,难于维护。

二.使用策略模式

  上面的案例就非常适合使用策略模式。策略模式对应于解决某一个问题的一个算法族,允许用户从该算法族中任选一个算法解决某一问题,同时可以方便的更换算法或者增加新的算法。并且由客户端决定调用哪个算法。我们通过案例来说明

1.案例类图

Java策略模式(Strategy)_策略模式

2.案例实现

Strategy接口

public interface Strategy {
public double getPrice(double standardPrice);
}

四种算法实现

public class NewCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("不打折,原价");
return standardPrice;
}
}
public class NewCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打九折");
return standardPrice*0.9;
}
}
public class OldCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八五折");
return standardPrice*0.85;
}
}
public class OldCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八折");
return standardPrice*0.8;
}
}

对外统一出口

/**
* 负责和具体的策略类交互
* 这样的话,具体的算法和直接的客户端调用分离了,使得算法可以独立于客户端独立的变化。
* 如果使用spring的依赖注入功能,还可以通过配置文件,动态的注入不同策略对象,动态的切换不同的算法.
* @author Administrator
*
*/
public class Context {
//当前采用的算法对象
private Strategy strategy;

//可以通过构造器来注入
public Context(Strategy strategy) {
super();
this.strategy = strategy;
}
//可以通过set方法来注入
public void setStrategy(Strategy strategy) {
this.strategy = strategy;
}
public void pringPrice(double s){
System.out.println("您该报价:"+strategy.getPrice(s));
}
}

测试

public static void main(String[] args) {
Strategy s1 = new OldCustomerManyStrategy();
Context ctx = new Context(s1);
ctx.pringPrice(998);
}

输出

打八折
您该报价:798.4000000000001

3.总结

  通过案例我们能清楚的看到,如果我们想要添加新的算法只需要再单独添加Strategy的实现就可以了,和其他算法没有影响。移除是也同样的道理,而且和客户端实现了分离。
  本质:分离算法,选择实现。

4.开发中的使用场景

  1. JAVASE中GUI编程中,布局管理
  2. Spring框架中,Resource接口,资源访问策略
  3. javax.servlet.http.HttpServlet#service()


举报

相关推荐

0 条评论