设计模式-策略模式(Strategy)

本文详细介绍了策略模式,一种设计模式,用于封装一系列算法并允许它们互换。策略模式通过定义策略接口和具体策略类,使得算法的变化独立于使用它的客户端。同时,文章还提供了策略模式的UML图和具体的代码实现示例,帮助读者更好地理解和应用这一模式。

一、策略模式(Strategy)

它定义了一系列的算法,将算法都分别封装起来,并且让它们之间可以相互替换(具有共性,有同一个策略接口),独立于使用它的人来独立变化

二、策略模式UML图


三、代码实现

Strategy类,定义所有支持的算法的公共接口

abstract class Strategy
{
    //算法方法
    public abstract void AlgorithmInterface();
}

ConcereteStrategy(具体策略),封装了具体的算法或行为,继承于Strategy

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


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

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

Context,用一个ConcreteStrategy来配置,维护一个队Strategy对象的引用

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

客户端代码

static void Main(string[] args)
{
    Context context;

    //由于实例化不同的策略,所以最终在调用context.ContextInterface();时,所获得的结果就不完全相同
    context = new Context(new ConcerteStrategyA());
    context.ContextInterface();

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

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

    Console.Read();
}

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值