定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。
UML结构图:
解析:
Observer模式定义的是一种一对多的关系,这里的一就是图中的Subject类,而多则是Obesrver类,当Subject类的状态发生变化的时候通知与之对应的Obesrver类们也去相应的更新状态,同时支持动态的添加和删除Observer对象的功能。Obesrver模式的实现要点是,第一一般subject类都是采用链表等容器来存放Observer对象,第二抽取出Observer对象的一些公共的属性形成Observer基类,而Subject中保存的则是Observer类对象的指针,这样就使Subject和具体的Observer实现了解耦,也就是Subject不需要去关心到底是哪个Observer对放进了自己的容器中。生活中有很多例子可以看做是Observer模式的运用,比方说,一个班有一个班主任(Subject),他管理手下的一帮学生(Observer),当班里有一些事情发生需要通知学生的时候,班主任要做的不是逐个学生挨个的通知而是把学生召集起来一起通知,实现了班主任和具体学生的关系解耦。
实现:
1)Observer.h
#ifndef OBSERVER_H #include <list> typedef int STATE; class Observer; // Subject抽象基类,只需要知道Observer基类的声明就可以了 void Notify(); // 通知对象改变状态 // 虚函数,提供默认的实现,派生类可以自己实现来覆盖基类的实现 protected: // Observer抽象基类 // 纯虚函数,各个派生类可能有不同的实现 protected: // ConcreateSubject类,派生在Subject类 // 派生类自己实现来覆盖基类的实现 }; // ConcreateObserver类派生自Observer // 虚函数,实现基类提供的接口 #endif |
#include "Observer.h" /**//* -------------------------------------------------------------------- void Subject::Attach(Observer *pObserver) m_ListObserver.push_back(pObserver); void Subject::Detach(Observer *pObserver) if (m_ListObserver.end() != iter) std::cout << "Detach an Observern"; void Subject::Notify() std::list<Observer*>::iterator iter1, iter2; for (iter1 = m_ListObserver.begin(), iter2 = m_ListObserver.end(); void Subject::SetState(STATE nState) STATE Subject::GetState() Subject::~Subject() for (iter1 = m_ListObserver.begin(), iter2 = m_ListObserver.end(); m_ListObserver.clear(); /**//* -------------------------------------------------------------------- STATE ConcreateSubject::GetState() /**//* -------------------------------------------------------------------- m_nObserverState = pSubject->GetState(); std::cout << "The ObeserverState is " << m_nObserverState << std::endl; |
3)Main.cpp
#include "Observer.h" int main() Subject* p = new ConcreateSubject; p->Detach(p1); delete p; system("pause"); return 0; |