设计模式之观察者模式
来源:互联网 发布:ios 知乎 编辑:程序博客网 时间:2024/06/04 18:35
一、模式动机
建立一种对象与对象之间的依赖关系,一个对象发生改变时将自动通知其他对象,其他对象将相应做出反应。在此,发生改变的对象称为观察目标,而被通知的对象称为观察者,一个观察目标可以对应多个观察者,而且这些观察者之间没有相互联系,可以根据需要增加和删除观察者,使得系统更易于扩展,这就是观察者模式的模式动机。
二、模式定义
观察者模式(Observer Pattern)定义了对象之间的一对多依赖,这样一来,当一个对象改变状态是,它的所有依赖者都会收到通知并自动更新。
观察者模式四个角色:
Subject:抽象主题
ConcreteSubject:具体目标
- Observer:观察者
- ConcreteObsever:具体观察者
三、模式示例
一个气象站当温度变化时,通知一些气象布告板。气象台就是主题对象,气象布告板则是观察者们。
目前我们设置三个气象布告板:目前状况、气象统计和天气预报。用户可以随心所欲得添加或删除任何布告板。
C++代码实现
#include <vector>#include <iostream>using namespace std;class Observer{public: virtual void update() = 0;};class GeneralDisplay : public Observer{public: void update(){ cout << "目前状况" << endl; }};class StatisticsDisplay : public Observer{public: void update(){ cout << "气象统计" << endl; }};class ForeCastDisplay : public Observer{public: void update(){ cout << "天气预报" << endl; }};class Subject{public: void registerObserver(Observer * observer) { observers.push_back(observer); } void removeObserver(Observer * observer) { for (vector<Observer*>::iterator iter = observers.begin(); iter != observers.end(); iter++) { if (*iter == observer) { observers.erase(iter); return; } } } void notifyObserver() { for (vector<Observer*>::iterator iter = observers.begin(); iter != observers.end(); iter++) { (*iter)->update(); } }protected: vector<Observer*> observers;};class WeatherData : public Subject{private: float temperature; float humidity; float pressure;};int _tmain(int argc, _TCHAR* argv[]){ Subject* weatherData = new WeatherData(); Observer* generalDisplay = new GeneralDisplay(); Observer* statisticsDisplay = new StatisticsDisplay(); Observer* foreCastDisplay = new ForeCastDisplay(); weatherData->registerObserver(generalDisplay); weatherData->registerObserver(statisticsDisplay); weatherData->registerObserver(foreCastDisplay); weatherData->notifyObserver(); delete generalDisplay; delete statisticsDisplay; delete foreCastDisplay; delete weatherData; system("pause"); return 0;}
运行结果:
四、分析总结
观察者模式中关键对象是观察目标和观察者,一个目标可以有任意数目的与之相依赖的观察者,一旦目标的状态发生改变,所有的观察者都将得到通知。观察者模式让主题和观察者之间送耦合,改变主题或者观察者的任何一方都不会影响另外一方。
MVC模式是一种架构模式,它包含三个角色:模型(Model),视图(View)和控制器(Controller)。观察者模式可以用来实现MVC模式,观察者模式中的观察目标就是MVC模式中的模型(Model),而观察者就是MVC中的视图(View),控制器(Controller)充当两者之间的中介者(Mediator)。当模型层的数据发生改变时,视图层将自动改变其显示内容。
优点
- 观察者模式可以实现表示层和数据逻辑层的分离,并定义了稳定的消息更新传递机制,抽象了更新接口,使得可以有各种各样不同的表示层作为具体观察者角色。
- 观察者模式在观察目标和观察者之间建立一个抽象的耦合。
- 观察者模式支持广播通信。
- 观察者模式符合“开闭原则”的要求。
缺点
- 如果一个观察目标对象有很多直接和间接的观察者的话,将所有的观察者都通知到会花费很多时间。
- 如果在观察者和观察目标之间有循环依赖的话,观察目标会触发它们之间进行循环调用,可能导致系统崩溃。
- 观察者模式没有相应的机制让观察者知道所观察的目标对象是怎么发生变化的,而仅仅只是知道观察目标发生了变化。
0 0
- 设计模式之-观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者
- 设计模式之观察者模式
- 设计模式之观察者模式
- 设计模式之观察者模式
- 设计模式之观察者模式
- 设计模式之观察者模式
- 设计模式之观察者模式
- 设计模式之观察者模式
- 我的春招总结
- Linux开机和关机记录查看
- MongoDB 3.0 的权限控制系统简介
- 表达式求值专题总结!
- 蓝桥杯 基础练习 数列特征 JAVA
- 设计模式之观察者模式
- Windows下安装scipy
- JAVA数据结构-单链表和HashMap
- R作图控制坐标轴刻度的个数和标注
- shell执行方式说明
- codeforces Polycarp at the Radio
- PHP——表单(1)
- opencv 常用数据格式
- 个人笔记整理-java设计模式之单例模式