设计模式学习笔记二十二——Strategy模式

本文介绍策略模式的应用案例——自动投票程序。通过定义不同的投票策略接口及其具体实现,展示如何让算法独立于客户端变化。
动机:定义一系列算法,把它们一个个封装起来,并且使它们可互相替换。该模式使得算法可独立于使用它的客户而变化。

场景:设计一个自动投票程序,根据常用投票对象的计票策略不同,定义一系列不同自动投票策略,可根据投票对象策略选用适当的自动投票策略。


结构
Strategy模式结构图

代码

namespace DesignPattern.Strategy
{
    
public interface IVoteStrategy
    
{
        
void Vote();

        
// 统计投票情况
        void Stat();
    }


    
public class VoteStrategyA : IVoteStrategy
    
{
        
public void Vote()
        
{
        }

        
public void Stat()
        
{
        }

    }


    
public class VoteStrategyB : IVoteStrategy
    
{
        
public void Vote()
        
{
        }

        
public void Stat()
        
{
        }

    }


    
public class VoteStrategyC : IVoteStrategy
    
{
        
public void Vote()
        
{
        }

        
public void Stat()
        
{
        }

    }

}

namespace DesignPattern.Strategy
{
    
public class AutoVote
    
{
        
private IVoteStrategy strategy;

        
public AutoVote(IVoteStrategy strategy)
        
{
            
this.strategy = strategy;
        }


        
public IVoteStrategy Strategy
        
{
            
set
            
{
                
this.strategy = value;
            }

        }


        
public void Vote()
        
{
            
//
            strategy.Vote();
        }


        
public void Stat()
        
{
            
//
            strategy.Stat();
        }

    }

}


要点
        1、Strategy及其子类为组件提供了一系列可重用的算法,从而使得类型在运行时方便地根据需要在各个算法之间进行切换,所谓封装算法,支持算法的变化。
        2、本模式提供了用条件判断语句以外的另一种选择,消除条件判断语句,就是在解耦。含有许多条件判断语句的代码通常都需要本模式。
        3、与State模式类似,如果Strategy对象没有实例变量,那么各个上下文可以共享同一个Strategy对象,从而节省对象开销。

转载于:https://www.cnblogs.com/Charly/archive/2007/08/24/867587.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值