快速导航
一、策略模式介绍
二、代码演示
三、jdk中使用 策略模式的地方
一、 策略模式介绍
定义: 定义了算法家族,分别封装起来,让他们之间可以相互替换,此模式让算法的变化不会影响到使用算法的用户。
if…else if …else if…else 模式
适用场景:
系统有很多类,而他们的区别仅仅在于他们的行为不同
一个系统需要动态地在几种算法中选择一种
优点:
开闭原则
避免使用多重条件转移语句
提高算法的保密性和安全性
缺点:
客户端必须知道所有的策略类,并自行决定使用哪一个策略类
产生很多策略类
相关设计模式:
策略模式和工厂模式
策略模式和状态模式
二、代码演示
//策略接口
public interface PromotionStrategy {
void doPromotion();
}
//返现策略
public class FanXianPromotionStrategy implements PromotionStrategy{
@Override
public void doPromotion() {
System.out.println("返现促销,返回的金额存放到慕课网用户的余额中");
}
}
//立减策略
public class LiJianPromotionStrategy implements PromotionStrategy {
@Override
public void doPromotion() {
System.out.println("立减促销,课程的价格直接减去配置的价格");
}
}
//满减策略
public class ManJianPromotionStrategy implements PromotionStrategy{
@Override
public void doPromotion() {
System.out.println("满减促销,满200-20元");
}
}
//活动类
public class PromotionActivity {
private PromotionStrategy promotionStrategy;
public PromotionActivity(PromotionStrategy promotionStrategy) {
this.promotionStrategy = promotionStrategy;
}
public void executePromotionStrategy(){
promotionStrategy.doPromotion();
}
}
//测试类
public class Test {
public static void main(String[] args) {
PromotionActivity promotionActivity618 = new PromotionActivity(new LiJianPromotionStrategy());
PromotionActivity promotionActivity1111 = new PromotionActivity(new FanXianPromotionStrategy());
promotionActivity618.executePromotionStrategy();
promotionActivity1111.executePromotionStrategy();
}
}
来看一下类的uml图:

执行结果: 按结果来看是按选择的策略执行的。

以上测试方法,需要强依赖PromotionStrategy 的实现类,每改一次都得改子类实现。
下面我们来优化一下代码,改为工厂模式:
//策略模式工厂
public class PromotionStrategyFactory {
private static final Map<String,PromotionStrategy> PROMOTION_STRATEGY_MAP=new HashMap<String,PromotionStrategy>();
private interface PromotionKey{
String LIJIAN="LIJIAN";
String FANXIAN="FANXIAN";
String MANJIAN="MANJIAN";
}
static {
PROMOTION_STRATEGY_MAP.put(PromotionKey.LIJIAN,new LiJianPromotionStrategy());
PROMOTION_STRATEGY_MAP.put(PromotionKey.FANXIAN,new FanXianPromotionStrategy());
PROMOTION_STRATEGY_MAP.put(PromotionKey.MANJIAN,new ManJianPromotionStrategy());
}
private PromotionStrategyFactory() { }
public static PromotionStrategy getPromotionStrategy(String key){
PromotionStrategy promotionStrategy = PROMOTION_STRATEGY_MAP.get(key);
return promotionStrategy==null? new NoPromotionStrategy():promotionStrategy;
}
}
//添加了无优惠的子实现类
public class NoPromotionStrategy implements PromotionStrategy {
@Override
public void doPromotion() {
System.out.println("无优惠活动");
}
}
//测试类
public class Test {
public static void main(String[] args) {
String strategy="MANJIAN";
PromotionStrategy promotionStrategy = PromotionStrategyFactory.getPromotionStrategy(strategy);
PromotionActivity promotionActivity = new PromotionActivity(promotionStrategy);
promotionActivity.executePromotionStrategy();
}
}
运行结果仍然是满足我们预期的:

三、jdk中使用 策略模式的地方
1、java.util.Comparator
java.util.Arrays 中的 sort() 方法是把 Comparator 作为参数,继续向下传,这就是策略模式在jdk中的典型应用。

2、java.util.TreeMap

3、org.springframework.core.io.Resource
下图标红的框都是 org.springframework.core.io.Resource 的行为策略实现



被折叠的 条评论
为什么被折叠?



