场景:
某个市场人员接到单后的报价策略(CRM常见)。报价策略很复杂,可以简单作如下分类:
普通客户小批量报价,普通客户大批量报价,老客户小批量报价,老客户大批量报价
具体选用哪个报价策略,这需要根据实际情况来定。这时候,我们采用策略模式即可。
本质:
分离算法,选择实现
使用场景:
1.javase中的GUI编程,布局管理
2.Spring框架中Resource接口,资源访问策略
3.javax.servlet.http.HttpServlet#service()
类图:
实现:
package com.gcxzflgl.strategy;
public interface Strategy {
public double getPrice(double standardPrice);
}
package com.gcxzflgl.strategy;
public class NewCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("不打折,原价");
return standardPrice;
}
}
package com.gcxzflgl.strategy;
public class NewCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打九折");
return standardPrice*0.9;
}
}
package com.gcxzflgl.strategy;
public class OldCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八五折");
return standardPrice*0.85;
}
}
package com.gcxzflgl.strategy;
public class OldCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八折");
return standardPrice*0.8;
}
}
package com.gcxzflgl.strategy;
/**
* 负责和具体的策略类交互
* 这样的话,具体的算法和直接的客户端调用分离了,使得算法可以独立于客户端独立的变化。
* 如果使用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));
}
}
package com.gcxzflgl.strategy;
public class Client {
public static void main(String[] args) {
Strategy s1 = new OldCustomerManyStrategy();
Context ctx = new Context(s1);
ctx.pringPrice(998);
}
}
对应不同的人群,选择不同的策略方式。