概要

  在软件构建过程中。我们须要为某些对象建立一种“通知依赖关系” ——一个对象(目标对象)的状态发生改变,全部的依赖对象(观察者对象)都将得到通知。假设这种依赖关系过于紧密,将使软件不能非常好地抵御变化。使用面向对象技术。能够将这种依赖关系弱化,并形成一种稳定的依赖关系。

从而实现软件体系结构的松耦合。

     意图

  定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 全部依赖于它的对象都得到通知并被自己主动更新。[GOF 《设计模式》]

 特点:

        1、  Subject和Observer之间是松偶合的,分别能够各自独立改变。

2、  Subject在发送广播通知的时候,无须指定详细的Observer。Observer能够自己决定是否要订阅Subject的通知。

        3、  遵守大部分GRASP原则和经常使用设计原则,高内聚、低偶合。

应用场景:

        1、  对一个对象状态的更新,须要其它对象同步更新,并且其它对象的数量动态可变。

        2、  对象仅须要将自己的更新通知给其它对象而不须要知道其它对象的细节。

        UML图

       

          代码实现

  1. #pragma once
  2. #include <string>
  3. #include <list>
  4. #include "Define.h"
  5. class IObserver;
  6. class ISubject
  7. {
  8. public:
  9. ISubject(void);
  10. virtual ~ISubject(void);
  11. virtual int Attach(IObserver* pObs) = 0;
  12. virtual int Detach(IObserver* pObs) = 0;
  13. virtual int Notify() = 0;
  14. virtual State GetState() = 0;
  15. virtual void SetState(const State& state) = 0;
  16. protected:
  17. typedef std::list<IObserver*> L_OBS;
  18. L_OBS   m_obsArray;
  19. };
  1. #pragma once
  2. #include "ISubject.h"
  3. class CSubjectA : public ISubject
  4. {
  5. public:
  6. CSubjectA(void);
  7. virtual ~CSubjectA(void);
  8. virtual int Attach(IObserver* pObs);
  9. virtual int Detach(IObserver* pObs);
  10. virtual int Notify();
  11. virtual State GetState();
  12. virtual void SetState(const State& state);
  13. private:
  14. State m_state;
  15. };
  1. #include "CSubjectA.h"
  2. #include "IObserver.h"
  3. CSubjectA::CSubjectA(void)
  4. {
  5. }
  6. CSubjectA::~CSubjectA(void)
  7. {
  8. if (!m_obsArray.empty())
  9. {
  10. m_obsArray.clear();
  11. L_OBS().swap(m_obsArray);
  12. }
  13. }
  14. int CSubjectA::Attach( IObserver* pObs )
  15. {
  16. m_obsArray.push_back(pObs);
  17. return 0;
  18. }
  19. int CSubjectA::Detach( IObserver* pObs )
  20. {
  21. m_obsArray.remove(pObs);
  22. return 0;
  23. }
  24. int CSubjectA::Notify()
  25. {
  26. L_OBS::iterator it_beg, it_end=m_obsArray.end();
  27. for (it_beg=m_obsArray.begin(); it_beg!=it_end; ++it_beg)
  28. {
  29. (*it_beg)->Update();
  30. }
  31. return 0;
  32. }
  33. State CSubjectA::GetState()
  34. {
  35. return m_state;
  36. }
  37. void CSubjectA::SetState( const State& state )
  38. {
  39. m_state = state;
  40. }
  1. #pragma once
  2. #include "Define.h"
  3. class IObserver
  4. {
  5. public:
  6. IObserver(void);
  7. virtual ~IObserver(void);
  8. virtual int Update() = 0;
  9. };
  1. #pragma once
  2. #include "IObserver.h"
  3. class ISubject;
  4. class CObserveA : public IObserver
  5. {
  6. public:
  7. CObserveA(ISubject* pSubject);
  8. virtual ~CObserveA(void);
  9. virtual int Update();
  10. private:
  11. ISubject* m_pSubject;
  12. };
  1. #include "CObserveA.h"
  2. #include <cstdio>
  3. #include "ISubject.h"
  4. CObserveA::CObserveA(ISubject* pSubject)
  5. :m_pSubject(pSubject)
  6. {
  7. m_pSubject->Attach(this);
  8. }
  9. CObserveA::~CObserveA(void)
  10. {
  11. m_pSubject->Detach(this);
  12. }
  13. int CObserveA::Update()
  14. {
  15. State str = m_pSubject->GetState();
  16. printf("first get: [%s]\n", str.c_str());
  17. return 0;
  18. }
  1. #include "CSubjectA.h"
  2. #include "CObserveA.h"
  3. int main()
  4. {
  5. CSubjectA subA;
  6. CObserveA first(&subA);
  7. subA.SetState("test set state");
  8. subA.Notify();
  9. return 0;
  10. }

版权声明:本文博客原创文章。博客,未经同意,不得转载。

C++设计模式--观察员的更多相关文章

  1. iOS中MVC等设计模式详解

    iOS中MVC等设计模式详解 在iOS编程,利用设计模式可以大大提高你的开发效率,虽然在编写代码之初你需要花费较大时间把各种业务逻辑封装起来.(事实证明这是值得的!) 模型-视图-控制器(MVC)设计 ...

  2. Cocos观察者设计模式和通报机制

    观察员(Observer)模式也称为公告/订阅(Publish/Subscribe)模式.这是 MVC( 模型-视图-控制器)模型的重要组成部分.天气一直讨论的英国最喜欢的话题,近期天气变化几年已成为 ...

  3. 北京设计模式学习组bjdp.org第7次活动(2013.08.04)回顾会纪要

    时间:2013.08.04,9am-7pm 地点:北京龙泉寺(北京凤凰岭风景区内) 参加人数:北京龙泉寺信息中心(20人).北京设计模式学习组(9人) 活动要点: 1)寺院巡礼:义工师兄带领参观寺院. ...

  4. MVVM设计模式和WPF中的实现(四)事件绑定

    MVVM设计模式和在WPF中的实现(四) 事件绑定 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在WPF中 ...

  5. java EE设计模式简介

    1.何为设计模式 设计模式提供了对常见应用设计问题的解决方案.在面向对象的编程中,设计模式通常在解决与对象创建和交互相关的问题,而非整体软件架构所面对的大规模问题,它们以样板代码的形式提供了通用的解决 ...

  6. 计算机程序的思维逻辑 (54) - 剖析Collections - 设计模式

    上节我们提到,类Collections中大概有两类功能,第一类是对容器接口对象进行操作,第二类是返回一个容器接口对象,上节我们介绍了第一类,本节我们介绍第二类. 第二类方法大概可以分为两组: 接受其他 ...

  7. 《JavaScript设计模式 张》整理

    最近在研读另外一本关于设计模式的书<JavaScript设计模式>,这本书中描述了更多的设计模式. 一.创建型设计模式 包括简单工厂.工厂方法.抽象工厂.建造者.原型和单例模式. 1)简单 ...

  8. 《JavaScript设计模式与开发实践》整理

    最近在研读一本书<JavaScript设计模式与开发实践>,进阶用的. 一.高阶函数 高阶函数是指至少满足下列条件之一的函数. 1. 函数可以作为参数被传递. 2. 函数可以作为返回值输出 ...

  9. 设计模式之行为类模式大PK

                                        行为类模式大PK 行为类模式包括责任链模式.命令模式.解释器模式.迭代器模式.中介者模式.备忘录模式.观察者模式.状态模式.策略 ...

随机推荐

  1. 翻转整数 Reverse digits of a number

    两种方法翻转一个整数.顺序翻转和递归翻转 这里没考虑overflow的情况 递归的作用是使得反向处理.即从递归栈的最低端開始处理.通过绘图可得. 假设是rec(num/10): 12345 1234 ...

  2. JSP自定义标签——简单标签(2)

    在前一篇博客中,我们已经学习了自定义的简单标签的基本使用方法,这一篇我们来学习如何在简单标签中添加标签属性.对自定义标签添加一些属性,可以使我们的标签功能更加灵活和复用.例如前一篇博客使用简单标签来对 ...

  3. 阿斯钢iojeg9uhweu9erhpu9hyw49

    http://www.huihui.cn/share/8424421 http://www.huihui.cn/share/8424375 http://www.huihui.cn/share/842 ...

  4. hdu5086——Revenge of Segment Tree

    Revenge of Segment Tree Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/ ...

  5. FastDFS概要

    本篇文章是我上级老大所写. 留在这里为了不弄丢. FastDFS是一款开源的轻量级分布式文件系统 纯C实现,支持Linux, FreeBSD等UNIX系统 类google FS, 不是通用的文件系统, ...

  6. Android Fragement学习笔记(三)----PreferenceFragment的使用

    相信大家对Perference都比較熟悉了,也就是我们常说的偏好设置,首选项设置,能够保存一些数据,比如我们在上一次使用的时候的一些内容,希望在下一次启动后依旧生效,而不须要再进行配置那么麻烦.一般这 ...

  7. (76) Clojure: Why would someone learn Clojure? - Quora

    (76) Clojure: Why would someone learn Clojure? - Quora ★ Why would someone learn Clojure?   Edit

  8. touch修改文件的修改时间和访问时间,ls --full-time显示文件详细,stat命令

    1. 同时修改文件的修改时间和访问时间 touch -d "2010-05-31 08:10:30" test.doc 2. 只修改文件的修改时间 touch -m -d &quo ...

  9. Ubuntu下实现双屏独立切换

    在编码时,总觉得屏幕大小不够,要是能多个屏多好,可以这样 把你的显示器连接到你的电脑,然后开启一个终端 输入:xrandr 显示如下: LVDS1 connected 1366x768+1024+0 ...

  10. sqlHelper的增删改查

    当一件事情被反复做了多次后.会想找一种办法来取代自己去做这个反复的动作. 敲代码也一样. 在程序中.对于反复的部分.假设是全然同样,那我们就会想着将其写成一个方法(过程.函数),放在一个具有权限的需求 ...