Headfirst设计模式的C++实现——策略模式(Strategy)
前言
最近在学习《Headfirst设计模式》,里面的例子都是Java的。但是我对Java并不熟悉,所以试着用C++来实现书中的例子。
先来看看Duck以及子类
Duck.h
#include <iostream>
#include "FlyBehavior.h" class Duck
{
private:
FlyBehavior *m_p_fly_behavior;
public:
virtual void quack() { std::cout << "--quack--" << std::endl; }
virtual void swim() { std::cout << "--swim--" << std::endl; }
virtual void display() { std::cout << "--duck--" << std::endl; } virtual void fly() { if ( m_p_fly_behavior) { m_p_fly_behavior->fly(); } };
void set_fly_behavior( FlyBehavior *p_fly_behavior) { m_p_fly_behavior = p_fly_behavior; } Duck() : m_p_fly_behavior(NULL) {}
virtual ~Duck() { if (m_p_fly_behavior) { delete m_p_fly_behavior; } }
};
MallardDuck.h
#include "Duck.h"
#include "FlyWithWings.h" class MallardDuck : public Duck
{
public:
void display() { std::cout << "--MallardDuck--" << std::endl; }
MallardDuck() { set_fly_behavior( new FlyWithWings() ); }
};
RedheadDuck.h
#include "FlyWithWings.h"
class RedheadDuck : public Duck
{
public:
void display() { std::cout << "--RedheadDuck--" << std::endl; }
RedheadDuck() { set_fly_behavior( new FlyWithWings() ); }
};
RubberDuck.h
#include "FlyNoWay.h" class RubberDuck : public Duck
{
public:
void display() { std::cout << "--RubberDuck--" << std::endl; }
void quack() { std::cout << "--squeak--" << std::endl; }
RubberDuck() { set_fly_behavior( new FlyNoWay() ); }
};
再来看看FlyBehavior类及其子类
FlyBehavior.h
#include <iostream> class FlyBehavior
{
public:
virtual void fly() {};
virtual ~FlyBehavior() {};
};
FlyWithWings.h
#include "FlyBehavior.h" class FlyWithWings : public FlyBehavior
{
public:
void fly () { std::cout << "--fly with wings--" << std::endl; }
};
FlyNoWay.h
#include "FlyBehavior.h" class FlyNoWay : public FlyBehavior
{
public:
void fly() { std::cout << "--can not fly--" << std::endl; }
};
最后是主函数
main.cpp
#include "MallardDuck.h"
#include "RedheadDuck.h"
#include "RubberDuck.h"
#include <vector> void test()
{
std::vector<Duck *> p_ducks;
p_ducks.push_back( new MallardDuck() );
p_ducks.push_back( new RedheadDuck() );
p_ducks.push_back( new RubberDuck() ); for (std::vector<Duck *>::iterator it = p_ducks.begin(); it < p_ducks.end(); it ++)
{
std::cout << std::endl;
(*it)->display();
(*it)->quack();
(*it)->swim();
(*it)->fly();
delete (*it);
}
} int main()
{
while (true)
{
test();
}
}
稍作解释
main函数中死循环的调用test函数的意图是测试以上实现有没有内存泄露。
Headfirst设计模式的C++实现——策略模式(Strategy)的更多相关文章
- HeadFirst设计模式读书笔记(1)-策略模式(Strategy Pattern)
策略模式(Strategy Pattern): 定义了了算法簇,分别封装起来,让它们之间可以相互替换,此模式让算法的变化独立于使用算法的客户端. 第一个设计原则:找出应用中可能需要变化之处,把他们独立 ...
- 设计模式(二)策略模式(Strategy)
1.分析项目中变化部分与不变部分 2.多用组合,少用继承:用行为类组合,而不是行为的继承 案例: 第一步,把行为抽象为接口 package top.littlepage.designPattern.S ...
- Delphi 设计模式:《HeadFirst设计模式》Delphi7代码---策略模式之MiniDuckSimulator[转]
1 2{<HeadFirst设计模式>之策略模式 } 3{ 本单元中的类为策略类 } 4{ 编译工具: Delphi7.0 } 5{ E- ...
- 【HeadFirst 设计模式总结】1.策略模式
1.书中举了一个鸭子类的设计,有些会飞或者会叫,有些不会飞可能也不会叫,用继承则导致不该有的功能通过继承而继承了下来,使用接口则代码无法做到最大程度的重用.进而引出设计原则1:找出应用中可能需要变化之 ...
- headfirst设计模式(1)—策略模式
什么是策略模式 策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.策略模式让算法独立于使用它的客户而独立变化(摘自百度百科) 关键字:算法封装,相互替换,独立变化 算法封装 ...
- 设计模式(二) 策略模式Strategy
策略模式是对算法的包装,是把使用算法的责任和算法本身分割开来,委派给不同的对象管理,我个人的理解是,具有相同行为不同的行为模式,比如走路,有人速度3m/s,有人100m/s,把他们的具体行走和对象本身 ...
- HeadFirst设计模式读书笔记之策略模式
1. 例子 1. 做一个鸭子模拟器,里面有很多不同的鸭子,有的可以游泳,有的可以睡觉,有的可以呱呱叫,一般套路是定义一个鸭子的超类,在 超类里定义睡觉,游泳,呱呱叫的方法,再让不同的鸭子子类继承这个超 ...
- 设计模式(一):“穿越火线”中的“策略模式”(Strategy Pattern)
在前段时间呢陆陆续续的更新了一系列关于重构的文章.在重构我们既有的代码时,往往会用到设计模式.在之前重构系列的博客中,我们在重构时用到了“工厂模式”.“策略模式”.“状态模式”等.当然在重构时,有的地 ...
- 【转】设计模式 ( 十八 ) 策略模式Strategy(对象行为型)
设计模式 ( 十八 ) 策略模式Strategy(对象行为型) 1.概述 在软件开发中也常常遇到类似的情况,实现某一个功能有多种算法或者策略,我们可以根据环境或者条件的不同选择不同的算法或者策略来完成 ...
随机推荐
- Trace、Debug和TraceSource的使用以及日志设计 .
[-] Trace 和 Debug区别 什么是Listeners 跟踪开关 使用BooleanSwitch开关 使用TraceSwitch开关 使用TraceSource代替Trace和Debug 设 ...
- 如何快速检查js语法学习Javascript
这里给大家推荐一个快速进行语法检查的方法,可以发现绝大多数语法错误,也可以作为在线编辑器,提高编程效率. 地址:http://www.jslint.com/ 同时推荐一个在线学习Javascript的 ...
- 基于jquery左侧带选项卡切换的焦点图
今天给大家分享一款基于jquery左侧带选项卡切换的焦点图.这款焦点图左侧有短标题,单击切换并显示长标题.效果图如下: 在线预览 源码下载 实现的代码. html代码: <div class ...
- 除去字符串中不相临的重复的字符 aabcad 得 aabcd
假设有一个字符串aabcad,请编写一段程序,去掉字符串中不相邻的重复字符.即上述字串处理之后结果是为:aabcd; 分析,重点考查 char 与int 的隐式转换.程序如下: static void ...
- sql中的or的用法说明
数据库里a c 0 10 20 31 41 51 6这样执行完这语句之后查出来有几条语句? 答案是3条 而我想要的是a为0或1并且c为3的数据显示 应该只有1条的 所以应该这样写 Sql ...
- LeetCode41 First Missing Positive
题目: Given an unsorted integer array, find the first missing positive integer. For example,Given [1,2 ...
- BootStrap2学习日记22---点击展开
先看效果: Code: <div class="accordion" id="accordion2"> <div class="ac ...
- 重构23-Introduce Parameter Object(参数对象)
有 时当 使用 一个 包含 多 个 参 数 的 方 法 时 , 由 于参 数 过 多 会 导 致 可 读 性 严 重 下 降 , 如 : 有 时当 使用 一个 包含 多 个 参 数 的 方 法 时 , ...
- Oracle基础 动态SQL语句
一.静态SQL和动态SQL的概念. 1.静态SQL 静态SQL是我们常用的使用SQL语句的方式,就是编写PL/SQL时,SQL语句已经编写好了.因为静态SQL是在编写程序时就确定了,我们只能使用SQL ...
- 放飞App:移动产品经理实战指南
<放飞App:移动产品经理实战指南> 基本信息 原书名:App savvy:rurning ideas into iPhone and iPad Apps customers really ...