java 策略模式 完全展现面向接口编程的经典样例

来源:互联网 发布:超级捕快软件 编辑:程序博客网 时间:2024/06/18 13:55

策略模式的定义:

策略模式定义了一些列的算法,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法独立于使用它的客户而独立变换。

乍一看,也没看出个所以然来。举个栗子吧。

假设我们要出去旅游,而去旅游出行的方式有很多,有步行,有坐火车,有坐飞机等等。而如果不使用任何模式,我们的代码可能就是这样子的。

public class TravelStrategy {enum Strategy{WALK,PLANE,SUBWAY}private Strategy strategy;public TravelStrategy(Strategy strategy){this.strategy=strategy;}public void travel(){if(strategy==Strategy.WALK){print("walk");}else if(strategy==Strategy.PLANE){print("plane");}else if(strategy==Strategy.SUBWAY){print("subway");}}public void print(String str){System.out.println("出行旅游的方式为:"+str);}public static void main(String[] args) {TravelStrategy walk=new TravelStrategy(Strategy.WALK);walk.travel();TravelStrategy plane=new TravelStrategy(Strategy.PLANE);plane.travel();TravelStrategy subway=new TravelStrategy(Strategy.SUBWAY);subway.travel();}}

这样做有一个致命的缺点,一旦出行的方式要增加,我们就不得不增加新的else if语句,而这违反了面向对象的原则之一,对修改封闭。而这时候,策略模式则可以完美的解决这一切。

首先,需要定义一个策略接口。

public interface Strategy {void travel();}

然后根据不同的出行方式实行对应的接口

public class WalkStrategy implements Strategy{@Overridepublic void travel() {System.out.println("walk");}}

public class PlaneStrategy implements Strategy{@Overridepublic void travel() {System.out.println("plane");}}

public class SubwayStrategy implements Strategy{@Overridepublic void travel() {System.out.println("subway");}}

此外还需要一个包装策略的类,并调用策略接口中的方法

public class TravelContext {Strategy strategy;public Strategy getStrategy() {return strategy;}public void setStrategy(Strategy strategy) {this.strategy = strategy;}public void travel() {if (strategy != null) {strategy.travel();}}}

测试一下代码

public class Main {public static void main(String[] args) {TravelContext travelContext=new TravelContext();travelContext.setStrategy(new PlaneStrategy());travelContext.travel();travelContext.setStrategy(new WalkStrategy());travelContext.travel();travelContext.setStrategy(new SubwayStrategy());travelContext.travel();}}

输出结果如下

plane
walk
subway

可以看到,应用了策略模式后,如果我们想增加新的出行方式,完全不必要修改现有的类,我们只需要实现策略接口即可,这就是面向对象中的对扩展开放准则。假设现在我们增加了一种自行车出行的方式。只需新增一个类即可。

public class BikeStrategy implements Strategy{@Overridepublic void travel() {System.out.println("bike");}}
之后设置策略即可

public class Main {public static void main(String[] args) {TravelContext travelContext=new TravelContext();travelContext.setStrategy(new BikeStrategy());travelContext.travel();}}

在android开发中,ViewPager是一个使用非常常见的控件,它的使用往往需要伴随一个Indicator指示器。如果让你重新实现一个ViewPager,并且带有Indicator,这时候,你会不会想到用策略模式呢?在你自己写的ViewPager中(不是系统的,当然你也可以继承系统的)持有一个策略接口Indicator的变量,通过set方法设置策略,然后ViewPager滑动的时候调用策略接口的对应方法改变指示器。默认提供几个Indicator接口的实现类,比如圆形指示器CircleIndicator、线性指示器LineIndicator、Tab指示器TabIndicator、图标指示器IconIndicator 等等等等。有兴趣的话自己去实现一个吧。

原创粉丝点击