策略模式(Strategy):定义了算法家族,分别封装起来,让他们之间可以相互替换,此模式让算法的变化,不会影响到使用算法的客户。
?
优点:
1、 简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试。
2、 避免程序中使用多重条件转移语句,使系统更灵活,并易于扩展。
3、 所以算法完成的都是相同的工作,只是实现不同,它可以以相同的方式调用所有的算法,减少了各种算法与使用算法类之间的耦合。
?
缺点:
1、 因为每个具体策略类都会产生一个新类,所以会增加系统需要维护的类的数量。
2、 在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转给策略模式的Context对象。
?
由于在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转给了策略模式Context对象。这本身并没有接触客户端需要选择判断的压力,而策略模式与简单工程模式结合后,选择具体实现的职责也可以由Context来承担,这就最大化地减轻了客户端的职责。
?
?
// Strategy.cpp : 定义控制台应用程序的入口点。 // #include stdafx.h #includeusing namespace std; /*************************************策略基类****************************************/ class StrategyBase//主要定义了虚函数 { public: virtual void multiWay_tour()=0;//说明是纯虚函数(没有实现的虚函数),必须如此声明 }; /*************************************具体策略类****************************************/ class StrategyFirstChild:public StrategyBase//策略子类,主要对父类定义的虚方法进行具体实现 { public: void multiWay_tour() { cout< { private: StrategyBase *strategyChild; public: Context(StrategyBase *child) { strategyChild=child; } void multiWay_tour() { strategyChild->multiWay_tour(); } }; /*************************************客户端****************************************/ int main() { cout<<测试程序< multiWay_tour(); Context_B->multiWay_tour(); Context_C->multiWay_tour();
delete Context_A;
delete Context_B;
delete Context_C;
cout<?
?