转自:http://blog.youkuaiyun.com/jungle_hello
定义
策略模式(Strategy)属于对象行为型设计模式,主要是定义一系列的算法,把这些算法一个个封装成拥有共同接口的单独的类,并且使它们之间可以互换。策略模式使这些算法在客户端调用它们的时候能够互不影响地变化。这里的算法不要狭义的理解为数据结构中算法,可以理解为不同的业务处理方法。
这种做法会带来什么样的好处呢?
它将算法的使用和算法本身分离,即将变化的具体算法封装了起来,降低了代码的耦合度,系统业务策略的更变仅需少量修改。
算法被提取出来,这样可以使算法得到重用,这种情况还可以考虑使用享元模式来共享算法对象,来减少系统开销(但要注意使用享元模式的建议条件)。
结构
先由定义来想象下它的结构吧:要使算法拥有共同的接口,这样就要实现一个接口或者
一个抽象类出来才行。这样基本上轮廓也就出来了,我们来看看吧:
策略模式由三个角色组成:
1) 算法使用环境角色(Context):算法被引用到这里和一些其它的与环境有关的操作一起来完成任务。
2) 抽象策略角色(Strategy):规定了所有具体策略角色所需的接口。在java 它通常由接口或者抽象类来实现。
3) 具体策略角色(Concrete Strategy):实现了抽象策略角色定义的接口。
策略模式各个角色之间关系的类图表示:
策略模式的实现
//抽象策略--Strategy-
public interface Calculate {
//一个待实现方法
int calculate(int a,int b);
}
//具体策略角色--Concrete Strategy1
public class AddCalculate implements Calculate {
@Override
//接口方法具体实现之加法
public int calculate(int a, int b) {
return a+b;
}
}
//具体策略角色--Concrete Strategy2
public class DivideCalculate implements Calculate{
@Override
//接口方法具体实现之除法
public int calculate(int a, int b) {
return a/b;
}
}
//算法使用环境角色--Context
public class EnvironmentRole {
private Calculate cal;
//构造方法对变量完成赋值
public EnvironmentRole(Calculate cal)
{
this.cal = cal;
}
//获得策略类对象
public Calculate getCalculate()
{
return cal;
}
//用set方法注入策略对象
public void setCalculate(Calculate cal)
{
this.cal = cal;
}
//环境角色中的接口方法,其具体结果依赖于策略引用指向的具体策略角色对象
public int calculate(int a,int b) {
return cal.calculate(a, b);
}
}
//一个客户端演示
public class Client {
public static void main(String[] args)
{
Calculate add = new AddCalculate();
EnvironmentRole environmentRole = new EnvironmentRole(add);
System.out.println(environmentRole.calculate(3, 4));
Calculate divide = new DivideCalculate();
EnvironmentRole environment = new EnvironmentRole(divide);
System.out.println(environment.calculate(9, 3));
}
}