观察者模式与Boost.Signals
1) 观察者模式定义
略,各种设计模式的书上都有定义。
2) 观察者模式一般实现
观察者模式一般实现,都是“被观察者”保存一个“观察者”的列表,循环这个列表来通知“观察者”。代码,其中使用了boost的智能指针shared_ptr:
- #include <iostream>
- #include <list>
- #include "boost/shared_ptr.hpp"
- using namespace std;
- using namespace boost;
- //观察者基类
- class Observer
- {
- public:
- //处理被观察者的通知
- virtual void update(const int i) = 0;
- };
- //观察者类A
- class ObserverA : public Observer
- {
- public:
- virtual void update(const int i)
- {
- cout << "ObserverA.update(" << i << ")" << endl;
- }
- };
- //观察者类B
- class ObserverB : public Observer
- {
- public:
- virtual void update(const int i)
- {
- cout << "ObserverB.update(" << i << ")" << endl;
- }
- };
- //被观察者基类
- class Subject
- {
- public:
- virtual ~Subject()
- {
- }
- //注册观察者
- virtual void reg(const shared_ptr<Observer>& pObs) = 0;
- //取消注册观察者
- virtual void unreg(const shared_ptr<Observer>& pObs) = 0;
- //通知观察者
- virtual void notify(const int i) = 0;
- };
- //被观察者类A
- class SubjectA : public Subject
- {
- public:
- virtual void reg(const shared_ptr<Observer>& pObs)
- {
- m_lstObs.push_back(pObs);
- }
- virtual void unreg(const shared_ptr<Observer>& pObs)
- {
- for (list<shared_ptr<Observer> >::iterator it = m_lstObs.begin();
- it != m_lstObs.end();)
- {
- if (pObs == *it) m_lstObs.erase(it++);
- else ++it;
- }
- }
- virtual void notify(const int i)
- {
- for (list<shared_ptr<Observer> >::iterator it = m_lstObs.begin();
- it != m_lstObs.end(); ++it)
- {
- (*it)->update(i);
- }
- }
- protected:
- //观察者类别
- list<shared_ptr<Observer> > m_lstObs;
- };
- int main()
- {
- //被观察者pSubA
- shared_ptr<Subject> pSubA(new SubjectA);
- //观察者pObsA
- shared_ptr<Observer> pObsA(new ObserverA);
- //观察者pObsB
- shared_ptr<Observer> pObsB(new ObserverB);
- //注册pObsA
- pSubA->reg(pObsA);
- //注册pObsB
- pSubA->reg(pObsB);
- //通知
- pSubA->notify(1); //显示
- //ObserverA.update(1)
- //ObserverB.update(1)
- //取消pObsA的注册
- pSubA->unreg(pObsA);
- //通知
- pSubA->notify(2); //显示
- //ObserverB.update(2)
- return 0;
- }
3) 观察者模式Boost.Signals实现
Boost.Signals是基于函数指针或函数对象来实现观察者模式的。其中Boost.Signals2是线程安全版本。代码:
- #include <iostream>
- #include <list>
- #include "boost/shared_ptr.hpp"
- #include "boost/signal.hpp"
- using namespace std;
- using namespace boost;
- //使用函数对象来实现
- //观察者类A
- class ObserverA
- {
- public:
- void operator()(const int i)
- {
- cout << "ObserverA(" << i << ")" << endl;
- }
- };
- //观察者类B
- class ObserverB
- {
- public:
- void operator()(const int i)
- {
- cout << "ObserverB(" << i << ")" << endl;
- }
- };
- int main()
- {
- //被观察者sig
- signal<void (const int)> sig;
- //注册观察者ObserverA
- signals::connection connA = sig.connect(ObserverA());
- //注册观察者ObserverB
- sig.connect(ObserverB());
- //通知
- sig(1); //显示
- //ObserverA(1)
- //ObserverB(1)
- //取消obsA的注册
- connA.disconnect();
- //通知
- sig(2); //显示
- //ObserverB(2)
- return 0;
- }
Boost.Signals还支持被观察者分组,可以对整个组进行“通知”、取消注册。另外,Boost.Signals需要编译才能使用。
观察者模式与Boost.Signals的更多相关文章
- boost::signals::signal的使用方法
吃力的讲完boost::signals的ppt.然后接着就是做练习题. 通过讲ppt,发现有一句话说的真好:你自己知道是一回事.你能给别人讲明确又是另外一回事.真的有些东西你自己理解,可是用语言去非常 ...
- vs2013 boost signals
#include "stdafx.h" #include <boost/signals2/signal.hpp> #include <iostream> u ...
- Linux上安装使用boost入门指导
Data Mining Linux上安装使用boost入门指导 获得boost boost分布 只需要头文件的库 使用boost建立一个简单的程序 准备使用boost二进制文件库 把你的程序链接到bo ...
- Windows下如何使用BOOST C++库 .
Windows下如何使用BOOST C++库 我采用的是VC8.0和boost_1_35_0.自己重新编译boost当然可以,但是我使用了 http://www.boostpro.com/produc ...
- 以boost::function和boost:bind取代虚函数
转自:http://blog.csdn.net/Solstice/archive/2008/10/13/3066268.aspx 这是一篇比较情绪化的blog,中心思想是“继承就像一条贼船,上去就下不 ...
- Win7下Boost库的安装
Boost库是C++领域公认的经过千锤百炼的知名C++类库,涉及编程中的方方面面,简单记录一下使用时的安装过程 1.boost库的下载 boost库官网主页:www.boost.org 2.安装 将下 ...
- VS2008下直接安装使用Boost库1.46.1版本号
Boost库是一个可移植.提供源码的C++库,作为标准库的后备,是C++标准化进程的发动机之中的一个. Boost库由C++标准委员会库工作组成员发起,当中有些内容有望成为下一代C++标准库内容.在C ...
- VS2008下直接安装使用Boost库1.46.1版本
Boost库是一个可移植.提供源代码的C++库,作为标准库的后备,是C++标准化进程的发动机之一. Boost库由C++标准委员会库工作组成员发起,其中有些内容有望成为下一代C++标准库内容.在C++ ...
- boost事件处理
尽管这个库的名字乍一看好象有点误导,但实际上并不是如此. Boost.Signals 所实现的模式被命名为 '信号至插槽' (signal to slot).它基于下面概念:当相应的信号被发出时.相关 ...
随机推荐
- Hacker(20)----手动修复Windows系统漏洞
Win7系统中存在漏洞时,用户需要采用各种办法来修复系统中存在的漏洞,既可以使用Windows Update修复,也可使用360安全卫士来修复. 一.使用Windows Update修复系统漏洞 Wi ...
- oracle服务的开始和关闭 CMD
开始: @echo halt oracle service ...net start OracleServiceORCLnet start OracleOraDb11g_home1TNSListene ...
- Geodatabase - 创建要素类.
在NET中,会遇到以“_2”结尾的属性,这些属性是可写的. 以下代码在已有工作空间下,创建一个新的点要素类: //例如,personalDBPath=@"G:\doc\gis\1.400\d ...
- OC基础 点语法的使用
OC基础 点语法的使用 1.创建一个Student类继承于NSObject,Student.h文件 #import <Foundation/Foundation.h> @interface ...
- iOS_SN_Xcode内存泄露调试
用Xcode进行内存调试有两种方法: 1.静态方法 2.动态方法 静态方法是直接在Xcode的菜单栏中选择product-->analyze 如截图所示. 之后会看到Xcode的编译状态上会有如 ...
- linux打开80端口及80端口占用解决办法
linux打开80端口天客户那边有台服务器同一个局域网中都无法访问,排除lamp环境问题,发现时服务器中的防火墙没有开启80端口. 代码如下 复制代码vi /etc/sysconfig/iptable ...
- zeromq源码分析笔记之线程间收发命令(2)
在zeromq源码分析笔记之架构说到了zmq的整体架构,可以看到线程间通信包括两类,一类是用于收发命令,告知对象该调用什么方法去做什么事情,命令的结构由command_t结构体确定:另一类是socke ...
- 流输入练习——寻找Sb.VI codevs 3096
题目描述 Description 已知某开放授权人员名叫Serb,由于经常修改各种数据,因此开发人员们都喊他SB.现在他和许多人一起过飞机安检,排成了一长队列,请问SB.是否在队列中. 输入描述 In ...
- Linux知识扫盲
1.发现linux中好多软件以d结尾,d代表什么? d 代表 deamon 守护进程守护进程是运行在Linux服务器后台的一种服务程序.现在比较常用 是 service 这个词.它周期性地执行某种任务 ...
- C#将十六进制的文本转换到整型数据
1 length1 = Int32.Parse(szLine.Substring(1, 2), System.Globalization.NumberStyles.HexNumber);//计算这一行 ...