1.策略模式 ①策略模式,是定义一系列的算法,把每一个算法封装起来,并且使它们可相互替换。策略模式模式使得算法可独立于使用它的客户而独立变化。 ②策略模式属于行为型模式。 ③策略模式提供了一组算法给客户端调用,使得客户端能够根据不同的条件来选择不同的策略来解决不同的问题。如排序算法,可以使用冒泡排序、快速排序等等。 ④if-else其实就是一个策略模式的体现,根据不同的选择处理不同的结果。但是,如果把所有的方法全部用if-else(switch)来处理,从功能上说没问题,但是冲代码层面的维护与使用来说,if-else多了之后会让类变的过于庞大,阅读不利,修改困难。因此,可以使用策略模式,定义统一接口,每一个不同的功能(if-else)实现接口做一个具体类,外部调用具体类来达到不同的结果。
2.应用场景 ①同一个问题具有不同算法时,即仅仅是具体的实现细节不同时,如各种排序算法等等。 ②对客户隐藏具体策略(算法)的实现细节,彼此完全独立;提高算法的保密性与安全性。 ③一个类拥有很多行为,而又需要使用if-else或者switch语句来选择具体行为时。使用策略模式把这些行为独立到具体的策略类中,可以避免多重选择的结构。
3.举例 有一个商品售卖,在售卖过程中,要根据不同的用户给予不同的价格(半价,9折,8折等等),在知道用户的前提下,如何直接给予价格呢? ①价格接口的实现 public interface PriceStrategy { int setPrice(int price); } ②实现具体的价格类 8折: public class eightPriceStrategy implements PriceStrategy { @Override public Double setPrice(int price) { return 0.8 * price; } } 5折: public class HalfPriceStrategy implements PriceStrategy { @Override public Double setPrice(int price) { return 0.5 * price; } } ③价格算法管理类 public class PriceAlgorithm { private PriceStrategy priceStrategy;
public PriceStrategy getPriceStrategy() { return priceStrategy; }
public void setPriceStrategy(PriceStrategy priceStrategy) { this.priceStrategy = priceStrategy; }
public Double getPrice(int price) { if(priceStrategy!=null){ return priceStrategy.setPrice(price); } return null; } } 传入具体的实现类,获取返回接口 ④调用方式 PriceAlgorithm priceAlgorithm = new PriceAlgorithm(); priceAlgorithm.setPriceStrategy(new HalfPriceStrategy()); System.out.print("\n" + “1块钱” + “5折后的价格:” + String.valueOf(priceAlgorithm.getPrice(1)));
PriceAlgorithm priceAlgorithm2 = new PriceAlgorithm(); priceAlgorithm2.setPriceStrategy(new eightPriceStrategy()); System.out.print("\n" + “2块钱” + “8折后的价格:” + String.valueOf(priceAlgorithm2.getPrice(2)));
4.优缺点 优点: ①策略类可以互相替换 由于策略类都实现同一个接口,因此他们能够互相替换。 ②耦合度低,方便扩展 增加一个新的策略只需要添加一个具体的策略类即可,基本不需要改变原有的代码,符合开闭原则。 使用策略模式之后的维护只需要维护具体的实现类,如果有新增的方式,只需要扩展实现具体类即可,便于维护使用。 ③避免使用多重条件选择语句(if-else或者switch)。
缺点: ①策略的增多会导致子类也会变多 ②客户端必须知道所有的策略类,并自行决定使用哪一个策略类。
5.Android中的源码分析 我们用ListView时都需要设置一个Adapter,而这个Adapter根据我们实际的需求可以用ArrayAdapter、SimpleAdapter等等,这里就运用到策略模式。 源码如下: public class ListView extends AbsListView {//相当于环境类 @Override public void setAdapter(ListAdapter adapter) {//设置策略,即adapter //其他代码略 } }
public interface ListAdapter extends Adapter {//抽象策略接口
}
public abstract class BaseAdapter implements ListAdapter, SpinnerAdapter {//具体策略类BaseAdapter,实现ListAdapter接口
}
public class ArrayAdapter extends BaseAdapter implements Filterable, ThemedSpinnerAdapter {//具体策略类ArrayAdapter,继承BaseAdapter,即实现ListAdapter接口
}
|