策略模式
2017-08-17 11:25
134 查看
本质:分离算法,选择实现
场景javase中GUI编程中,布局管理器;spring框架中,resoyrce接口,资源访问策略;javax.servlet.http.httpservlet#service()
例子:比如商城打折,老用户新商品打9折,老用户老商品打8折,新用户新商品减10元,新用户老商品减20元
Strategy.java(策略类)
public interface Strategy {
public double getPrice(double standardPrice);
}
OldCustomerManyStrategy.java
public class OldCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八折");
return standardPrice*0.8;
}
}
OldCustomerFewStrategy.java
public class OldCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八五折");
return standardPrice*0.85;
}
}
NewCustomerManyStrategy.java
public class NewCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打九折");
return standardPrice*0.9;
}
}
NewCustomerFewStrategy.java
public class NewCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("不打折,原价");
return standardPrice;
}
}
Context.java
/**
* 负责和具体的策略类交互
* 这样的话,具体的算法和直接的客户端调用分离了,使得算法可以独立于客户端独立的变化。
* 如果使用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 class Client {
public static void main(String[] args) {
Strategy s1 = new OldCustomerManyStrategy();
Context ctx = new Context(s1);
ctx.pringPrice(998);
}
}
注意:如果使用ifelse,实现起来比较容易,符合一般开发人员的思路,假如,类型特别多,算法比较复杂时,整个条件语句的代码就变得很长,难于维护。如果有新增类型,就需要频繁的修改此处的代码!不符合开闭原则!
场景javase中GUI编程中,布局管理器;spring框架中,resoyrce接口,资源访问策略;javax.servlet.http.httpservlet#service()
例子:比如商城打折,老用户新商品打9折,老用户老商品打8折,新用户新商品减10元,新用户老商品减20元
Strategy.java(策略类)
public interface Strategy {
public double getPrice(double standardPrice);
}
OldCustomerManyStrategy.java
public class OldCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八折");
return standardPrice*0.8;
}
}
OldCustomerFewStrategy.java
public class OldCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打八五折");
return standardPrice*0.85;
}
}
NewCustomerManyStrategy.java
public class NewCustomerManyStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("打九折");
return standardPrice*0.9;
}
}
NewCustomerFewStrategy.java
public class NewCustomerFewStrategy implements Strategy {
@Override
public double getPrice(double standardPrice) {
System.out.println("不打折,原价");
return standardPrice;
}
}
Context.java
/**
* 负责和具体的策略类交互
* 这样的话,具体的算法和直接的客户端调用分离了,使得算法可以独立于客户端独立的变化。
* 如果使用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 class Client {
public static void main(String[] args) {
Strategy s1 = new OldCustomerManyStrategy();
Context ctx = new Context(s1);
ctx.pringPrice(998);
}
}
注意:如果使用ifelse,实现起来比较容易,符合一般开发人员的思路,假如,类型特别多,算法比较复杂时,整个条件语句的代码就变得很长,难于维护。如果有新增类型,就需要频繁的修改此处的代码!不符合开闭原则!
相关文章推荐
- 研磨设计模式之 策略模式-5
- 设计模式之Strategy(策略)
- 设计模式(策略模式)
- 策略模式
- Java设计模式之策略模式详解
- 设计模式之策略模式、观察者模式浅析
- 【设计模式】策略模式
- JS设计模式之策略模式概念与用法分析
- 《Header First 设计模式》之策略模式
- 设计模式利剑12-策略模式
- 持久化模式,第 1 部分:现代 ORM 工具的策略和最佳实践
- java中的策略模式
- 设计模式--策略模式
- 设计模式(二十二) 策略模式
- 设计模式一 前言与策略模式(strategy)
- 策略模式VS桥梁模式
- Java开发模式--策略模式
- 策略模式
- 行为型模式-Strategy ( 策略模式 )
- Head First Design patterns笔记-Strategy Patterns (从不同的人使用不同的交通工具上班看策略模式)