设计模式之策略模式

策略模式是设计模式中属于行为型模式,它的作用是让一个类的行为或者其算法可以在运行时更改。在策略模式中,我们创建表示各种策略的对象和一个行为随着策略对象改变而改变的context(环境)对象。策略对象改变context对象的执行算法。

我们来看一下策略模式类图

从中可以看到Strategy(策略)是下方ABC三个类的父类,与Context(环境)有着聚合和单向关联关系。根据类图,我们来看一下代码部分:

这是策略类,创建一个算法接口,用来连接具体类算法:

    /// <summary>
    /// 抽象类算法:策略
    /// </summary>
    abstract class Strategy
    {
        //算法接口  
        public abstract void AlgorithmInterface();

    }

这是具体算法的三个类,通过继承“策略”重写“AlgorithmInterface(算法接口)”

    /// <summary>
    /// 具体算法A
    /// </summary>
    class ConcreteStrategyA : Strategy
    {
        //算法A实现方法
        public override void AlgorithmInterface()
        {
            Console.WriteLine("算法A实现");
        }
    }

    /// <summary>
    /// 具体算法B
    /// </summary>
    class ConcreteStrategyB : Strategy
    {
        //算法B实现方法
        public override void AlgorithmInterface()
        {
            Console.WriteLine("算法B实现");
        }
    }


    /// <summary>
    /// 具体算法C
    /// </summary>
    class ConcreteStrategyC : Strategy
    {
        //算法C实现方法
        public override void AlgorithmInterface()
        {
            Console.WriteLine("算法C实现");
        }
    }

当然,其中的“context(环境)”是上下文中的连接类

    class Context
    {
        Strategy strategy;
        /// <summary>
        /// 初始化时,传入具体的策略对象
        /// </summary>
        /// <param name="strategy"></param>
        public Context(Strategy strategy)
        {
            this.strategy = strategy;
        }
        /// <summary>
        /// 上下文接口,根据具体的策略对象,调用其算法的方法
        /// </summary>
        public void ContextInterface()
        {
            strategy.AlgorithmInterface();
        }
    }

这是策略模式的客户端代码

        static void Main(string[] args)
        {
            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();

        }

看过上边的代码后,重新整理基本定义,这是定义算法家族,分别封装起来,让它们之间可以互相替换,这样可以让算法变化时,不会影响到用户的使用。

这种模式适用于类种的成员以方法为主,算法经常变动;简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试。策略模式和简单工厂基本相同,但简单工厂模式只能解决对象创建问题,对于经常变动的算法应使用策略模式。

但是这种模式需要客户端(客户)来做出判断。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李金轩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值