创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下♡>𖥦<)!!
主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步!
🔥c++系列专栏:C/C++零基础到精通 🔥给大家跳段街舞感谢支持!ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ
c语言内容💖:
专栏:c语言之路重点知识整合
【c语言】全部知识点总结
目录
- 一、观察者模式的实现
- 二、示例
观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。
当主题对象状态发生变化时,它的所有依赖者(观察者)都会自动收到通知并更新
一、观察者模式的实现
- 1. 定义观察者接口:包含 update 更新方法,定义为虚函数
- 2. 创建具体观察者:实现观察者接口,定义接收到通知时的更新动作
- 3. 定义主题接口:添加、删除和通知观察者
- 4. 创建具体主题:实现主题接口,实现观察者列表,更新数据时通知观察者
二、示例
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <string>
#include <vector>
#include <time.h>
using namespace std;//接口
class Observer
{
public:virtual ~Observer() {}virtual void update(const string& data) = 0; // 接收主题发送的数据
};//主题对象
class Subject
{
public:virtual ~Subject() {}virtual void attach(Observer* observer) = 0; // 添加观察者 virtual void detach(Observer* observer) = 0; // 移除观察者 virtual void notify() = 0; // 通知所有观察者
};class ConcreteSubject : public Subject
{
private:vector<Observer*> observers;string data;public:// 添加观察者 void attach(Observer* observer) override {observers.push_back(observer);}// 移除观察者 void detach(Observer* observer) override {auto it = find(observers.begin(), observers.end(), observer);if (it != observers.end()){observers.erase(it);}}// 通知观察者 void notify() override {for (auto observer : observers) {//调用更新函数observer->update(data);}}//数据更新void setData(const string& newData) {data = newData;notify(); // 当数据改变时,通知所有观察者 }
};//主题对象更新
class ConcreteObserver : public Observer
{
private:string name;public:ConcreteObserver(const string& name) : name(name) {}void update(const string& data) override {cout << name << " TianXiStudio time: " << data << endl;}
};int main()
{//创建主题对象ConcreteSubject subject;//创建两个观察者ConcreteObserver observer1("Observer 1");ConcreteObserver observer2("Observer 2");//两个观察者依赖主题对象subject.attach(&observer1);subject.attach(&observer2);//数据更新time_t now;time(&now);subject.setData(ctime(&now));return 0;
}
大家的点赞、收藏、关注将是我更新的最大动力! 欢迎留言或私信建议或问题。 |
大家的支持和反馈对我来说意义重大,我会继续不断努力提供有价值的内容!如果本文哪里有错误的地方还请大家多多指出(●'◡'●) |