首页 > 代码库 > 策略模式 Strategy模式
策略模式 Strategy模式
Strategy模式:
定义了算法家族,分别封装起来,让它们之间可以互相替换。
基本特点:
a)根据不同的情况,创建不同的对象
b)每个对象方法名相同,方法的实现差别很大
组成:
1个抽象策略;
n个具体策略(封装了相关的算法)
1个调度类,它拥有一个策略类的引用
代码例子:
// Strategy.cpp : 定义控制台应用程序的入口点。//#include "stdafx.h"#include <iostream>using namespace std;/************************************************************************//* Stragey模式就是将算法封装到一个类里面,然后在调用类里面调用这个类 *//************************************************************************//*weaponStrategy类,是所有武器的基类,也就是所有算法的公共接口*/class weaponStrategy{public: virtual void attack() = 0;};//下面就是三个具体的算法class arrow : public weaponStrategy{public: virtual void attack() { cout<<"我的武器是绿箭侠的绿箭"<<endl; }};class sword : public weaponStrategy{public: virtual void attack() { cout<<"我的武器是张无忌的倚天剑"<<endl; }};class knife : public weaponStrategy{public: virtual void attack() { cout<<"我的武器是萧十一郎的割鹿刀"<<endl; }};/*策略模式所用的就是 聚合 的思想,简单点来说就是一个类中A定义另外一个类的对象B,然后通过B实现本应该在A当中实现的功能*/class soldierContext{public: soldierContext(weaponStrategy* weapon) { this->pWeapon = weapon; } void DoAction() { pWeapon->attack(); } ~soldierContext() { delete pWeapon; }private: weaponStrategy* pWeapon;};//策略模式是一种定义一系列算法的方法,从概念上来看,所有这些算法完成的都是相同的工作,只是实现不同,//它可以以相同的方式调用所有的算法,减少了各种算法类于使用算法类之间的耦合。int _tmain(int argc, _TCHAR* argv[]){ /* 使用弓箭还是割鹿刀还是倚天剑,这三个武器相当于三个策略A、B、C,下面三个策略可以互相转化 */ weaponStrategy* pWeapon = new arrow(); soldierContext* pSolider = new soldierContext(pWeapon); pSolider->DoAction(); pWeapon = new knife();//转化到割鹿刀策略 pSolider = new soldierContext(pWeapon); pSolider->DoAction(); pWeapon = new sword();//转化到倚天剑策略 pSolider = new soldierContext(pWeapon); pSolider->DoAction(); getchar(); return 0;}
简单工厂模式与策略模式的区别:
简单工厂模式注重不同对象的创建,比如动物类,创建猫类,狗类;
策略模式注重的是多个对象的相同行为,比如上面都是电影DoAction()行为,但是里面的算法实现细节不同。
(说实话,现在要让自己选择用一个还是不太清除怎么选择,估计以后用的情况多了就明白了,现在只要先理解策略模式的样式就好了)
策略模式 Strategy模式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。