策略模式--条条大路通罗马(行为模式07)

来源:互联网 发布:js刷新页面 编辑:程序博客网 时间:2024/06/14 06:49

什么是策略模式
策略模式定义了一系列封装好的算法,使他们可以相互替换。
策略模式让算法独立于使用他的客户端独立变化。

策略模式的适用场景
同一种问题有多重处理方式,仅仅在具体实现有差别
需要安全的封装同一类型的操作
实现同一抽象有多个子类,而又需要适用分支操作选择具体子类时

策略模式用例
我们从出发地到目的地可以选择坐公交车,也可以选择打的,公交车比较便宜实惠,打的比较贵但是快且舒适,选择哪一种方式都能实现目的,但是根据实际情况,比如时间紧迫怕堵车可以选择摩的,不怕挤可以选择公交,想要舒适的环境可以多花点钱打的等。

UML用例图
这里写图片描述

IPrice接口:

public interface IPrice {    int calculatePrice(int distance);}

BusStrategy:

public class BusStrategy implements IPrice {    @Override    public int calculatePrice(int distance) {        // 公交车票价,起步价1元,3公里外每公里加一元        int total = distance - 3;        int mPrice = total + 1;        return distance>0?mPrice:1;    }}

CarStrategy:

public class CarStrategy implements IPrice {    @Override    public int calculatePrice(int distance) {        // 出租车票价,起步价5元,3公里外每公里加3元        int total = distance - 3;        int mPrice = total*3 + 5;        return distance>0?mPrice:5;    }}

测试类:

public class Test {    BusStrategy bs;    CarStrategy cs;    public static void main(String[] args) {        //公交车        Test test = new Test();        test.setBusStrategy(new BusStrategy());        System.out.println("公交车价格:"+test.calculateBusPrice(10)+" 元");        //出租车        Test test2 = new Test();        test2.setCarStrategy(new CarStrategy());        System.out.println("出租车价格:"+test2.calculateCarPrice(10)+" 元");    }    public void setBusStrategy(BusStrategy bs){        this.bs = bs;    }    public int calculateBusPrice(int distance){        return bs.calculatePrice(distance);    }    public void setCarStrategy(CarStrategy cs){        this.cs = cs;    }    public int calculateCarPrice(int distance){        return cs.calculatePrice(distance);    }}

测试结果:

公交车价格:8 元出租车价格:26 元

策略模式总结:
策略模式主要用来分离算法步骤,比如这个我们把公交和出租车分开来计算,解耦操作。
优点:结构清晰,使用简单。耦合度低,扩展方便。操作封装彻底,数据安全。
缺点:随着策略增多,子类更多,比如我们要加入火车、飞机、轮船等等交通工具。