我所理解的设计模式(C++实现)——观察者模式(Observer Pattern)

概述:

近期中国股市起起伏伏,当然了起伏就用商机,小明发现商机后果断想入市,买入了中国证券,他想在电脑client上,网页上,手机上,iPad上都能够查看到该证券的实时行情,这样的情况下我们应该怎么设计我们的软件呢?我们能够这样:小明的全部client上都订阅中国证券这个股票,仅仅要股票一有变化,全部的client都会被通知到而且被自己主动更新。

这就是我们的观察者模式,她定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 全部依赖于它的对象都得到通知并被自己主动更新。

类图与实例:

能够看出,在这个观察者模式的实现里有以下这些角色:

        抽象主题(Subject)角色:主题角色把全部对观察考对象的引用保存在一个聚集里,每一个主题都能够有不论什么数量的观察者。抽象主题提供一个接口,能够添加和删除观察者对象,主题角色又叫做抽象被观察者(Observable)角色,一般用一个抽象类或者一个接口实现。

        抽象观察者(Observer)角色:为全部的详细观察者定义一个接口,在得到主题的通知时更新自己。这个接口叫做更新接口。抽象观察者角色一般用一个抽象类或者一个接口实现。在这个示意性的实现中,更新接口仅仅包括一个方法(即Update()方法),这种方法叫做更新方法。

       详细主题(ConcreteSubject)角色:将有关状态存入详细现察者对象;在详细主题的内部状态改变时,给全部登记过的观察者发出通知。详细主题角色又叫做详细被观察者角色(Concrete Observable)。详细主题角色通经常使用一个详细子类实现。

        详细观察者(ConcreteObserver)角色:存储与主题的状态自恰的状态。详细现察者角色实现抽象观察者角色所要求的更新接口,以便使本身的状态与主题的状态相协调。假设须要,详细现察者角色能够保存一个指向详细主题对象的引用。详细观察者角色通经常使用一个详细子类实现。

从详细主题角色指向抽象观察者角色的合成关系,代表详细主题对象能够有随意多个对抽象观察者对象的引用。之所以使用抽象观察者而不是详细观察者,意味着主题对象不须要知道引用了哪些ConcreteObserver类型,而仅仅知道抽象Observer类型。这就使得详细主题对象能够动态地维护一系列的对观察者对象的引用,并在须要的时候调用每个观察者共同拥有的Update()方法。这样的做法叫做"针对抽象编程"。

        这里我们提供一个简单化的实例:

#include <iostream>
#include <vector>
#include <string>
using namespace std;
class Secretary;
// 看股票的同事类(观察对象,观察者)
class StockObserver
{
public:
	StockObserver(string strName, Secretary* strSub)
	{
		name = strName;
		sub = strSub;
	}

	void Update();

private:
	string name;
	Secretary* sub;
};

// 秘书类(主题对象,通知者)
class Secretary
{

public:
	string action;
	void Add(StockObserver ob) { observers.push_back(ob); }
	void Remove(int addIndex)
	{
		if(addIndex >=0 && addIndex < observers.size())
		observers.erase(observers.begin() + addIndex);
	}
	void Notify()
	{
		vector<StockObserver>::iterator it;
		for (it=observers.begin(); it!=observers.end(); ++it)
		{
			(*it).Update();
		}
	}

private:
	vector<StockObserver> observers;
};

void StockObserver::Update()
{
	cout << name << " : " << sub->action << ", begin to work" << endl;
}

int main()
{
	// 创建通知者
	Secretary* p = new Secretary();

	// 观察者
	StockObserver* s1 = new StockObserver("Lazy", p);
	StockObserver* s2 = new StockObserver("SnowFire", p);

	// 增加通知队列
	p->Add(*s1);
	p->Add(*s2);

	// 事件
	p->action = "The boss is coming...";

	// 通知
	p->Notify();

	// 动态删除
	p->Remove(0);

	p->Notify();

	return 0;

}

适用性:

1.当一个抽象模型有两个方面, 当中一个方面依赖于还有一方面。将这二者封装在独立的对象中以使它们能够各自独立地改变和复用。

2.当对一个对象的改变须要同一时候改变其他对象, 而不知道详细有多少对象有待改变。

3.当一个对象必须通知其他对象,而它又不能假定其他对象是谁。换言之, 你不希望这些对象是紧密耦合的。

优缺点:

观察者模式的效果有下面几个长处:

1.观察者模式在被观察者和观察者之间建立一个抽象的耦合。被观察者角色所知道的仅仅是一个详细现察者聚集,每个详细现察者都符合一个抽象观察者的接口。被观察者并不认识不论什么一个详细观察者,它仅仅知道它们都有一个共同的接口。因为被观察者和观察者没有紧密地耦合在一起,因此它们能够属于不同的抽象化层次。

2.观察者模式支持广播通信。被观察者会向全部的登记过的观察者发出通知。

观察者模式有以下的一些缺点:

1.假设一个被观察者对象有非常多直接和间接的观察者的话,将全部的观察者都通知到会花费非常多时间。

2.假设在被观察者之间有循环依赖的话,被观察者会触发它们之间进行循环调用,导致系统崩溃。在使用观察考模式时要特别注意这一点。

3.假设对观察者的通知是通过另外的线程进行异步投递的话,系统必须保证投递是以自恰的方式进行的。

4.尽管观察者模式能够随时使观察者知道所观察的对象发生了变化,可是观察者模式没有对应的机制使观察者知道所观察的对象是怎么发生变化的。

其它:

1.在.NET中能够利用Delegate与Event机制来实现观察者模式。

2.Java提供了Observer 和Observable来帮助我们简化实现观察者模式。

LCL_data原创于CSDN.NET【http://blog.csdn.net/lcl_data/article/details/9208561

其它设计模式请參考我所理解的设计模式

时间: 2024-10-18 14:18:01

我所理解的设计模式(C++实现)——观察者模式(Observer Pattern)的相关文章

我理解设计模式C++实现观察者模式Observer Pattern

概述: 近期中国股市起起伏伏,当然了起伏就用商机,小明发现商机后果断想入市,买入了中国证券,他想在电脑client上,网页上,手机上,iPad上都能够查看到该证券的实时行情,这样的情况下我们应该怎么设计我们的软件呢?我们能够这样:小明的全部client上都订阅中国证券这个股票,仅仅要股票一有变化,全部的client都会被通知到而且被自己主动更新. 这就是我们的观察者模式,她定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 全部依赖于它的对象都得到通知并被自己主动更新. 类图与实例:

设计模式 - 观察者模式(Observer Pattern) 详解

观察者模式(Observer Pattern) 详解 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26583157 版权所有, 禁止转载, 如有转载, 请站内联系. 观察者模式(Observer Pattern): 定义了对象之间的一对多的依赖, 这样一来, 当一个对象改变状态时, 它的所有依赖者都会收到通知并自动更新. 使用方法: 1. 首先新建主题(subject)接口, 负责注册(register)\删除(remove

设计模式 - 观察者模式(Observer Pattern) Java内置 使用方法

观察者模式(Observer Pattern) Java内置 使用方法 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26601659 观察者模式(observer pattern)详解, 参见: http://blog.csdn.net/caroline_wendy/article/details/26583157 Java内置的观察者模式, 是通过继承父类, 实现观察者模式的几个主要函数: Observerable(可被观

Java设计模式之观察者模式(Observer Pattern)

Observer Pattern 是一种常用的设计模式,它是一种事件监听模型.该模式有两个角色,一个是Subject, 另一个是Observer.Subject 保存有多个Observer的引用,一旦特定的事件发生,Subject会通知它所有的Observer,Observer得到该通知后执行相关程序逻辑.其中,Observer只有先向Subject注册后才能被Subject知晓.这就像订报纸,只有我们向出版社提出订报的申请,出版社才会把我们列入订阅者名单,然后每当新报纸印好时,出版社会通知订阅

设计模式 - 观察者模式(Observer Pattern) 详细说明

观察者模式(Observer Pattern) 详细说明 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26583157 版权全部, 禁止转载, 如有转载, 请站内联系. 观察者模式(Observer Pattern): 定义了对象之间的一对多的依赖, 这样一来, 当一个对象改变状态时, 它的全部依赖者都会收到通知并自己主动更新. 用法: 1. 首先新建主题(subject)接口, 负责注冊(register)\删除(remo

jQuery中的观察者模式(Observer Pattern)

在jQuery中,on方法可以为元素绑定事件,trigger方法可以手动触发事件,围绕这2个方法,我们来体验jQuery中的观察者模式(Observer Pattern). ■ on方法绑定内置事件,自然触发 比如,我们给页面的body元素绑定一个click事件,这样写. <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title&

设计模式之二:观察者模式(Observer Pattern)

先看下观察者模式的定义: The Observer Pattern defines a one-to-many denpendency between objects so that when one object changes state, all of its dependents are notified and updated automatically.:观察者模式定义了对象间一对多依赖关系,使得当一个对象改变状态,则所有依赖于它的对象都会得到通知并被自动更新. 观察者模式又叫发布-

【设计模式】观察者模式 Observer Pattern

定义:观察者模式定义了对象之间的一对多依赖.当“主题”(Object)状态改变事,所有依赖它的“观察者”(Observer)都会受到通知并自动更新.主题支持观察者订阅和退订. 观察者模式提供了一种对象设计,让主题和观察者之间松耦合.改变主题或观察者一方不会影响另一方.因为两者是松耦合的. 参考: 设计模式学习笔记--Observer Pattern观察者模式

设计模式----行为型模式之观察者模式(Observer Pattern)

下面是阅读<Head First设计模式>的笔记. 观察者模式 定义了对象之间的一对多依赖,这样一来,当一个对象改变状态时,它的所有依赖者都会收到通知并自动更新. JDK API内置机制 JDK1.0版本就已经包含了java.util.Observer和java.util.Observable,TODO. java.util.Observer是一个接口,所有使用内置机制实现观察者模式,都需要实现该接口.该接口只定义了一个方法 void update(Observable o, Object a

设计模式(行为型)之观察者模式(Observer Pattern)

PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbober] 阅读前一篇<设计模式(结构型)之代理模式(Proxy Pattern)>http://blog.csdn.net/yanbober/article/details/45480965 概述 观察者模式用于建立一种对象与对象之间的依赖关系,一个对象发生改变时将自动通知其他对象,其他对象将相应作