Strategy 策略(行为型模式)--学习笔记
2007-04-09 06:15
288 查看
问题:算法与对象的耦合 对象可能经常需要使用多种不同的算法,但是如果变化频繁,会将类型变得脆弱…
下面的代码在应对这种变化时将修改原来的代码,我们的原则是 要扩展不要修改
enum CartType
{
A,
B,
C,
}
class Cart
{
public Point[] GetAlignment(CartType cartType)
{
if(cartType == CartType.A)
{
ProcessA();
}
else if(cartType == CartType.B)
{
ProcessB();
}
else if(cartType == CartType.C)
{
ProcessC();
}
}
protected virtual void ProcessA()
{
}
protected virtual void ProcessB()
{
}
protected virtual void ProcessC()
{
}
}
动机(Motivation):
在软件构建过程中,某些对象使用的算法可能多种多样,经常改变,如果将这些算法都编码到对象中,将会使对象变得异常复杂;而且有时候支持不使用的算法也是一个性能负担。
解决思路:在运行时根据需要透明地更改对象的算法,将算法与对象本身解耦,从而避免上述问题。
public interface IProcessStrategy //表达算法抽象
public class ProcessStrategyA:IProcessStrategy
public class ProcessStrategyB:IProcessStrategy
public class ProcessStrategyC:IProcessStrategy
class Cart
public class app
//接口更能表达抽象的含义,委托只要求方法的签名一致即可。
结构:
Strategy模式的几个要点
• Strategy及其子类为组件提供了一系列可重用的算法,从而可以使得类型在运行时方便地根据需要在各个算法之间进行切换。所谓封装算法,支
持算法的变化。
• Strategy模式提供了用条件判断语句以外的另一种选择,消除条件判断语句,就是在解耦合。含有许多条件判断语句的代码通常都需要Strategy模式。
• 与State类似,如果Strategy对象没有实例变量,那么各个上下文可以共享同一个Strategy对象,从而节省对象开销。
下面的代码在应对这种变化时将修改原来的代码,我们的原则是 要扩展不要修改
enum CartType
{
A,
B,
C,
}
class Cart
{
public Point[] GetAlignment(CartType cartType)
{
if(cartType == CartType.A)
{
ProcessA();
}
else if(cartType == CartType.B)
{
ProcessB();
}
else if(cartType == CartType.C)
{
ProcessC();
}
}
protected virtual void ProcessA()
{
}
protected virtual void ProcessB()
{
}
protected virtual void ProcessC()
{
}
}
动机(Motivation):
在软件构建过程中,某些对象使用的算法可能多种多样,经常改变,如果将这些算法都编码到对象中,将会使对象变得异常复杂;而且有时候支持不使用的算法也是一个性能负担。
解决思路:在运行时根据需要透明地更改对象的算法,将算法与对象本身解耦,从而避免上述问题。
public interface IProcessStrategy //表达算法抽象
public class ProcessStrategyA:IProcessStrategy
public class ProcessStrategyB:IProcessStrategy
public class ProcessStrategyC:IProcessStrategy
class Cart
public class app
//接口更能表达抽象的含义,委托只要求方法的签名一致即可。
结构:
Strategy模式的几个要点
• Strategy及其子类为组件提供了一系列可重用的算法,从而可以使得类型在运行时方便地根据需要在各个算法之间进行切换。所谓封装算法,支
持算法的变化。
• Strategy模式提供了用条件判断语句以外的另一种选择,消除条件判断语句,就是在解耦合。含有许多条件判断语句的代码通常都需要Strategy模式。
• 与State类似,如果Strategy对象没有实例变量,那么各个上下文可以共享同一个Strategy对象,从而节省对象开销。
相关文章推荐
- 设计模式学习笔记(3)之策略设计模式(Strategy)
- 设计模式学习笔记--策略(Strategy)模式
- 设计模式 学习笔记 之 策略模式 Strategy(4)
- 【设计模式】学习笔记1:策略模式(Strategy)
- java 设计模式学习笔记十五 strategy 策略设计模式
- 设计模式学习笔记(四):策略模式【Strategy】
- 设计模式深入学习--Strategy 策略模式(行为型模式)
- 设计模式学习笔记(六)之策略模式(Strategy)
- java 设计模式学习笔记十五 strategy 策略设计模式
- 【设计模式学习笔记二十二】【行为模式】【策略模式(Strategy)】
- 步步为营 .NET 设计模式学习笔记 三、Strategy(策略模式)
- Design Patterns学习笔记:Strategy策略模式
- 十一个行为型模式9:策略模式-Strategy Pattern【学习难度:★☆☆☆☆,使用频率:★★★★☆】
- 步步为营 .NET 设计模式学习笔记 三、Strategy(策略模式)
- 设计模式学习笔记(六)之策略模式(Strategy)
- 设计模式学习之策略模式(Strategy,行为型模式)(13)
- 设计模式学习笔记--Strategy 策略模式
- [学习笔记]Head First 设计模式 - 策略模式(Strategy)
- 设计模式学习笔记二:Strategy,策略模式
- 步步为营 .NET 设计模式学习笔记 三、Strategy(策略模式)