美文网首页
策略模式

策略模式

作者: Davisxy | 来源:发表于2019-05-07 11:56 被阅读0次
  • 策略模式对应于解决某一个问题的一个算法族,允许用户从该算法族中任选一个算法解决某一个问题,同时可以方便的更换算法或者增加新的算法。并且由客户端决定调用哪个算法。

小栗子

  • 不采用策略模式:
package com.principle.strategy;
/**
 * 没采用策略模式
 * 实现起来容易
 * 假如,类型比较多,算法复杂则难以维护,不符合开闭原则
 * @author xy
 *
 */
public class TestStrategy {
    public static void main(String[] args) {
        
    }
    
    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;
    }
}
  • 采用策略模式
package com.principle.strategy;

public interface Strategy {
    double getPrice(double standardPrice);
}
package com.principle.strategy;

public class NewCustomerFewStrategy implements Strategy{

    @Override
    public double getPrice(double standardPrice) {
        System.out.println("不打折,原价");
        return standardPrice;
    }

}
package com.principle.strategy;

public class NewCustomerManyStrategy implements Strategy{

    @Override
    public double getPrice(double standardPrice) {
        System.out.println("打九折");
        return standardPrice*0.9;
    }

}
package com.principle.strategy;

public class OldCustomerFewStrategy implements Strategy{

    @Override
    public double getPrice(double standardPrice) {
        System.out.println("打八五折");
        return standardPrice*0.85;
    }

}
package com.principle.strategy;

public class OldCustomerManyStrategy implements Strategy{

    @Override
    public double getPrice(double standardPrice) {
        System.out.println("打八折");
        return standardPrice*0.8;
    }

}
package com.principle.strategy;

/**
 * 负责和具体额策略类交互
 * 这样的话,具体的算法和直接的客户端调用分离了,使得算法可以独立于客户端独立的变化。
 * 如果使用spring的依赖注入功能,还可以通过配置文件,动态的注入不同的策略对象,动态的切换不同的算法
 * @author xy
 *
 */
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 printPrice(double s){
        System.out.println("您该报价:"+strategy.getPrice(s));
    }
    

}
package com.principle.strategy;

public class Client {
    public static void main(String[] args) {
        Strategy s1=new OldCustomerManyStrategy();
        Context context=new Context(s1);
        context.printPrice(998);
    }
}
控制台打印:
打八折
您该报价:798.4000000000001

类图

策略模式.png

本质:

  • 分离算法,选择实现。

相关文章

网友评论

      本文标题:策略模式

      本文链接:https://www.haomeiwen.com/subject/hdupnqtx.html