什么是策略模式
策略模式对应解决某一个问题的一个算法族,允许用户从该算法族中任选一个算法解决某一个问题,同时可以方便的更换算法或者增加新的算法,并且由客户端觉得调用哪个算法。
策略模式的本质就是分离算法,选择实现.
案例:某个市场人员接到单后的报价策略(CRM系统中常见问题)。报价策略很复杂,可以简单作如下分类:
- 普通客户小批量报价
- 普通客户大批量报价
- 老客户小批量报价
- 老客户大批量报价
具体选用哪个报价策略,这需要根据实际情况来确定。这时候,我们采用策略模式即可。
非策略模式实现的优劣
非策略模式,实现起来比较容易,符合一般开发人员的思路
- 假如:类型特别多,算法比较复杂时,整个条件语句的代码就变得很长,难于维护
- 如果有新增类型,就需要频繁的修改此处的代码
- 不符合开闭原则
模式主要组成
Context:环境角色,持有一个Strategy的引用。
Strategy:抽象策略角色,通常有一个接口或抽象类实现,定义所有具体策略类需要的接口。
ConcreteStrategy:具体策略角色,包装了相关的算法或行为。
实现策略模式的经典案例
Context:
/**
*
* @author 233admincol
*@description 环境角色,管理算法
*负责和具体的策略类交互
*/
public class Context {
private Strategy strategy; // 当前采用的算法对象
// 可以通过构造器注入
public Context(Strategy strategy) {
this.strategy = strategy;
}
// 可以通过set方法注入
public void setContext(Strategy strategy){
this.strategy = strategy;
}
// 打印报价的方法,(可选)
public void pringPice(double d){
System.out.println("您该报价: " + strategy.getPrice(d));
}
}
Strategy
/**
*
* @author 233admincol
*抽象策略角色
*/
public interface Strategy {
public double getPrice(double standarPrice);
}
ConcreteStrategy
/**
*
* @author 233admincol
*具体策略角色,普通客户,小批量
*/
public class NewCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standarPrice) {
System.out.println("不打折,原价");
return standarPrice;
}
}
/**
*
* @author 233admincol
*具体策略角色,普通客户,大批量
*/
public class NewCustomerManyStrategy implements Strategy{
@Override
public double getPrice(double standarPrice) {
System.out.println("打九折");
return standarPrice*0.9;
}
}
/**
*
* @author 233admincol
* 具体策略角色,老客户,小批量
*/
public class OldCustomerFewStrategy implements Strategy{
@Override
public double getPrice(double standarPrice) {
System.out.println("打八五折");
return standarPrice*0.85;
}
}
/**
*
* @author 233admincol
*具体策略角色,老客户,大批量
*/
public class OldCustomerManyStrategy implements Strategy{
@Override
public double getPrice(double standarPrice) {
System.out.println("打八折");
return standarPrice*0.8;
}
}
测试代码
public class Test {
public static void main(String[] args) {
Strategy s1 = new OldCustomerManyStrategy();
Context ctx = new Context(s1);
ctx.pringPice(998);
}
}
执行后
打八折
您该报价: 798.4000000000001