创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下♡>𖥦<)!!
主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步!
🔥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;
}
大家的点赞、收藏、关注将是我更新的最大动力! 欢迎留言或私信建议或问题。 |
大家的支持和反馈对我来说意义重大,我会继续不断努力提供有价值的内容!如果本文哪里有错误的地方还请大家多多指出(●'◡'●) |