设计模式笔记 22. Strategy 策略模式(行为型模式)

本文介绍了设计模式中的策略模式,包括其动机、意图及基本代码实现。策略模式定义了一系列算法并将其封装,使算法能够独立于使用它的客户而变化。

22. Strategy 策略模式

2008-09-24

动机(Motivation)

在软件构建过程中,某些对象使用的算法可能多种多样,经常改变,如果将这些算法都编码到对象中,将会使对象变得异常复杂;而且有时候支持不使用的算法也是一个性能负担。

如何在运行时根据需要透明地更改对象的算法?将算法与对象本身解耦,从而避免上述问题?

意图(Intent)

定义一系列算法,把它们一个个封装起来,并且使它们可互相替换。该模式使得算法可独立于使用它的客户而变化。                          ——《设计模式》GoF

如果除去Context类,这个模式几乎跟模板方法一样,可以看到,策略模式只是比模板方法模式多了一个Context类这个包装器。

  基本代码:
    //抽象算法类
    abstract class Strategy
ExpandedBlockStart.gifContractedBlock.gif    
{
        
//算法方法
        public abstract void AlgorithmInterface();
    }
 
    //具体算法A
    class ConcreteStrategyA : Strategy
ExpandedBlockStart.gifContractedBlock.gif    
{
        
//算法A实现方法
        public override void AlgorithmInterface()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            Console.WriteLine(
"算法A实现");
        }

    }


    
//具体算法B
    class ConcreteStrategyB : Strategy
ExpandedBlockStart.gifContractedBlock.gif    
{
        
//算法B实现方法
        public override void AlgorithmInterface()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            Console.WriteLine(
"算法B实现");
        }

    }


    
//具体算法C
    class ConcreteStrategyC : Strategy
ExpandedBlockStart.gifContractedBlock.gif    
{
        
//算法C实现方法
        public override void AlgorithmInterface()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            Console.WriteLine(
"算法C实现");
        }

    }
 
    //上下文
    class Context
ExpandedBlockStart.gifContractedBlock.gif    
{
        Strategy strategy;

        
public Context(Strategy strategy)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            
this.strategy = strategy;
        }

        
//上下文接口
        public void ContextInterface()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            strategy.AlgorithmInterface();
        }

    }
  客户端调用:
    class Program
ExpandedBlockStart.gifContractedBlock.gif    
{
        
static void Main(string[] args)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            Context context;

            context 
= new Context(new ConcreteStrategyA());
            context.ContextInterface();

            context 
= new Context(new ConcreteStrategyB());
            context.ContextInterface();

            context 
= new Context(new ConcreteStrategyC());
            context.ContextInterface();

            Console.Read();
        }

    }
 

Strategy的几个要点:

Strategy及其子类为组件提供了一系列可重用的算法,从而可以使得类型在运行时方便地根据需要在各个算法之间进行切换。

Strategy模式提供了用条件判断语句以外的另一种选择,消除条件判断语句,就是在解耦合。含有许多条件判断语句的代码通常都需要Strategy模式。

State类似,如果Strategy对象没有实例变量,那么各个上下文可以共享同一个Strategy对象,从而节省对象开销。

 

转载于:https://www.cnblogs.com/MaoBisheng/archive/2008/09/24/1298271.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值