设计模式-策略模式

2019-08-09 00:00:00 模式 设计

这是一个在书上看到的例子,在这里简单记录一下。

1.需求

一个销售书籍的系统,实现:每种书的折扣不一样,教材类的8折,小说类7折,生活类5折,其他的没有折扣。

2.容易想到的解决方法

通常我们会写一个方法计算每种书的价格,代码如下:

private int caculatePrice(String bookType, int originalPrice) {
    int price = originalPrice;
    if (bookType.equals("教材")){
        price = 计算教材价格的算法;
    }else if (bookType.equals("小说")){
        price = 计算小说价格的算法;
    }else if (bookType.equals("生活")){
        price = 计算生活价格的算法;
    }
    return price;
}

3.使用策略模式实现

简单理解:策略模式就是就是为了解决上面这种需求,取代上面这种条件选则语句的实现方式。

如何实现策略模式呢,看图:

《设计模式-策略模式》

上图很容易理解,定义一个计算价格的接口,三种计算价格的算法放到三个实现类(在这个模式中叫策略类)里面,这么容易理解的图就不上代码了(脑补就出来了)。代码脑补出来之后,就可以使用多态的方式来实现对不同价格算法的调用了,多态不是很理解的话 可以看这里。好吧,其实不知道多态的话也很容易看懂的:

PriceCalculator  pc = new EDUPriceCalculator(); //超类引用指向子类EDUPriceCalculator对象
pc.caculatePrice(price); //这里调用子类EDUPriceCalculator里面的方法,也就是计算教育类书籍的价格

一般我们都会把上面的代码放到一个客户类里面,所以最终策略模式的代码结构为:一个客户类,一个抽象策略类(接口),若干个具体策略类。最后由客户类决定选择哪一个策略类。上面的类图中已经包含了抽象策略类具体策略类,还差一个客户类,代码如下:

public class CalculatorClient {
    PriceCaculator caculator; //抽象策略接口PriceCaculator的引用
    public void setCaculator(PriceCaculator c) {
        caculator = c;
    }
    
    public void caculatorPrice() {
        caculator.caculatorPrice();
    }
}

到这里,策略模式已经完成了,使用的时候只需要通过客户类指定调用哪一种算法即可

//首先定义一个客户类
CalculatorClient client = new CalculatorClient();

//动态设定策略类,并调用其算法
EDUPriceCalculator eduCalculator = new EDUPriceCalculator();
client.setCaculator(eduCalculator);
client.caculatorPrice();

//动态设定策略类,并调用其算法
NovelPriceCalculator novelCalculator = new NovelPriceCalculator();
client.setCaculator(novelCalculator);
client.caculatorPrice();

//动态设定策略类,并调用其算法
LifePriceCalculator lifeCalculator = new LifePriceCalculator();
client.setCaculator(lifeCalculator);
client.caculatorPrice();

好了,到这里再看一下策略模式的概念:策略模式定义了一系列算法,并将每个算法封装起来,使他们可以相互替换,且算法的变化不会影响到使用算法的客户。是不是很容易理解了?

相关文章