观察者模式:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。它还有两个别名,依赖(Dependents),发布-订阅(Publish-Subsrcibe)。可以举个博客订阅的例子,当博主发表新文章的时候,即博主状态发生了改变,那些订阅的读者就会收到通知。博主与读者之间存在一对多的依赖关系。下面给出相应的UML图设计:

可以看到博客类中有一个观察者链表(即订阅者),当博客的状态发生变化时,通过Notify成员函数通知所有的观察者,告诉他们博客的状态更新了。而观察者通过Update成员函数获取博客的状态信息。代码实现不难,下面给出C++的一种实现。

//观察者
class Observer
{
public:Observer() {}virtual ~Observer() {}virtual void Update() {}
};
//博客
class Blog
{
public:Blog() {}virtual ~Blog() {}void Attach(Observer *observer) { m_observers.push_back(observer); }     //添加观察者void Remove(Observer *observer) { m_observers.remove(observer); }        //移除观察者void Notify() //通知观察者{list<Observer*>::iterator iter = m_observers.begin();for(; iter != m_observers.end(); iter++)(*iter)->Update();}virtual void SetStatus(string s) { m_status = s; } //设置状态virtual string GetStatus() { return m_status; }    //获得状态
private:list<Observer* > m_observers; //观察者链表
protected:string m_status; //状态
};

以上是观察者和博客的基类,定义了通用接口。博客类主要完成观察者的添加、移除、通知操作,设置和获得状态仅仅是一个默认实现。下面给出它们相应的子类实现。

//具体博客类
class BlogCSDN : public Blog
{
private:string m_name; //博主名称
public:BlogCSDN(string name): m_name(name) {}~BlogCSDN() {}void SetStatus(string s) { m_status = "CSDN通知 : " + m_name + s; } //具体设置状态信息string GetStatus() { return m_status; }
};
//具体观察者
class ObserverBlog : public Observer
{
private:string m_name;  //观察者名称Blog *m_blog;   //观察的博客,当然以链表形式更好,就可以观察多个博客
public: ObserverBlog(string name,Blog *blog): m_name(name), m_blog(blog) {}~ObserverBlog() {}void Update()  //获得更新状态{ string status = m_blog->GetStatus();cout<<m_name<<"-------"<<status<<endl;}
};

客户的使用方式:

//测试案例
int main()
{Blog *blog = new BlogCSDN("wuzhekai1985");Observer *observer1 = new ObserverBlog("tutupig", blog);blog->Attach(observer1);blog->SetStatus("发表设计模式C++实现(15)——观察者模式");blog->Notify();delete blog; delete observer1;return 0;
}

设计模式C++实现——观察者模式相关推荐

  1. 设计模式 ( 十六 ) 观察者模式Observer(对象行为型)

    设计模式 ( 十五 ) 观察者模式Observer(对象行为型) 1.概述 一些面向对象的编程方式,提供了一种构建对象间复杂网络互连的能力.当对象们连接在一起时,它们就可以相互提供服务和信息. 通常来 ...

  2. 设计模式(四) Observe——观察者模式

    设计模式四 Observe--观察者模式 观察者模式 当对象间存在一对多关系时,则使用观察者模式(Observer Pattern).比如,当一个对象被修改时,则会自动通知它的依赖对象.观察者模式属于 ...

  3. Java 设计模式之《观察者模式》

    很久之前,自己也曾看过一些设计模式的内容,最近在做一些程序代码设计的时,发现忘得差不多了,很多模式也只是有大致影响,决定重新将一些常用的模式复习一下.今天一个模式观察者模式. 观察者模式 观察者模式属 ...

  4. 设计模式学习(二): 观察者模式 (C#)

    <深入浅出设计模式>学习笔记第二章 需求: 开发一套气象监测应用,如图: 气象站,目前有三种装置,温度.湿度和气压感应装置. WeatherData对象追踪气象站的数据,并更新到布告板,布 ...

  5. 设计模式-策略模式,观察者模式,装饰者模式,静态工厂模式,工厂方法模式

    设计模式这个东西,永远不是单单从书本上就能获取到的东西.曾经看到一个比喻,比喻的就很巧妙,文艺复兴时期的教学方式,那时候诞生了很多巨匠,达芬奇,莫开朗基罗,拉斐尔都是在这个时期绽放光芒的巨星.有一种说 ...

  6. Java设计模式10:观察者模式

    观察者模式 观察者模式也叫作发布-订阅模式,也就是事件监听机制.观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,这个主题对象在状态上发生变化时,会通知所有观察者对象,使他 ...

  7. 大话设计模式Python实现-观察者模式

    观察者模式(发布-订阅模式 Publish Subscribe Pattern):定义了一种一对多的关系,让多个观察对象同时监听一个主题对象,当主题对象状态发生变化时会通知所有观察者,是它们能够自动更 ...

  8. 开发之路(设计模式二:观察者模式)

    继续我们的设计模式学习,有个好的"观察者"可以让你开发效率大大提高 直接进入正题,我们用一个气象站程序来模拟此模式. 有一个气象站程序,能对湿度,温度,气压进行监测并显示在&quo ...

  9. 设计模式中的观察者模式

    观察者模式是一种软件设计模式,其中一个名为主体(Subject)的对象维护其依赖项列表,称为观察者,并通常通过调用它们(observers)的方法之一来自动通知它们任何状态更改. 观察者模式主要用于在 ...

最新文章

  1. php layui table,layui table 相关问题汇总
  2. Maze Problem(求最短距离)BFS
  3. 阿里 mysql 架构_阿里java架构教你怎么用mysql怒怼面试官
  4. Sqlserver中格式化日期作为查询条件的语句写法
  5. C语言 枚举,进制,原码,反码,补码,移码,结构体
  6. 【python数据挖掘课程】十一.Pandas、Matplotlib结合SQL语句可视化分析
  7. zookeeper windows 下安装
  8. arm workbench ide 用户指南_ARM_异常和中断
  9. clear linux安装教程,Clear Linux OS特性介绍,附下载地址
  10. mysql limitorderby
  11. 【资料】翘首期盼247天!《阿里巴巴Java开发手册》扫描插件详情介绍
  12. java中的对象传递
  13. newaxis取出某一行或列数据以及增加维度
  14. XX项目技术架构模板
  15. java影视app对接cms,原生影视App双端对接飞飞CMS
  16. RGB渐变色与HSL渐变色
  17. c语言中用梯形法求定积分
  18. python两个表格相同数据筛选_python如何统计所有文本文件的行数 如何用python实现两个文件重复数据筛选并统计...
  19. 232电平和TTL电平
  20. 自动给ssh输入密码(python使用pty模块,或者script命令)

热门文章

  1. JS正则判断输入框是否仅仅含有汉字、字母和数字
  2. 第三次spring冲刺1
  3. Android fastjson
  4. [f]动态判断js加载完成
  5. 解决svn错误:post-commit hook failed (exit code 1) with output
  6. python3.7 ‘utf-8‘ codec can‘t decode byte 0xbe in position 0: invalid start byte
  7. Swift之深入解析可选链的功能和使用
  8. 下列关于物理层设备的叙述中,错误的是( )
  9. 647. Palindromic Substrings 回文子串
  10. 76. 最小覆盖子串