C++ 设计模式:观察者模式(Observer Pattern)

链接:C++ 设计模式
链接:C++ 设计模式 - 模板方法
链接:C++ 设计模式 - 策略模式

观察者模式(Observer Pattern)是一种行为设计模式,它定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。当主题对象的状态发生变化时,它会通知所有观察者对象,使它们能够自动更新。

1.问题分析

在开发中,经常会遇到需要在一个对象状态变化时通知其他对象的情况。如果将通知逻辑直接嵌入到主题对象中,会导致代码耦合度高,难以维护和扩展。观察者模式通过将观察者对象和主题对象解耦,使得它们可以独立变化。

2.实现步骤

  1. 定义观察者接口:定义一个接口,包含更新方法。
  2. 定义主题接口:定义一个接口,包含注册、注销和通知观察者的方法。
  3. 实现具体主题类:具体主题类实现主题接口,并维护一个观察者列表。
  4. 实现具体观察者类:具体观察者类实现观察者接口,并在更新方法中实现具体的响应逻辑。

3.代码示例

以机器人电池电量作为示例:

3.1.观察者接口

cpp 复制代码
// 定义更新方法
class Observer {
 public:
  virtual ~Observer() = default;
  virtual void update(int batteryLevel) = 0;
};

3.2. 主题接口

cpp 复制代码
// 定义添加、删除和通知观察者的方法
class Subject {
 public:
  virtual ~Subject() = default;
  virtual void addObserver(std::shared_ptr<Observer> observer) = 0;
  virtual void removeObserver(std::shared_ptr<Observer> observer) = 0;
  virtual void notifyObservers() = 0;
};

3.3.具体主题类

cpp 复制代码
// 实现主题接口
class Robot : public Subject {
 public:
  void addObserver(std::shared_ptr<Observer> observer) override { observers.push_back(observer); }

  void removeObserver(std::shared_ptr<Observer> observer) override {
    observers.erase(std::remove(observers.begin(), observers.end(), observer), observers.end());
  }

  void notifyObservers() override {
    for (const auto& observer : observers) {
      observer->update(batteryLevel);
    }
  }

  void setBatteryLevel(int level) {
    batteryLevel = level;
    notifyObservers();
  }

 private:
  std::vector<std::shared_ptr<Observer>> observers;
  int batteryLevel = 100;
};

3.4.具体观察者类

cpp 复制代码
// 具体观察者类1,显示电池电量
class BatteryDisplay : public Observer {
 public:
  void update(int batteryLevel) override { std::cout << "BatteryDisplay: Battery level is " << batteryLevel << "%" << std::endl; }
};
cpp 复制代码
// 具体观察者类2,当电池电量低于20%时发出警告
class BatteryWarning : public Observer {
 public:
  void update(int batteryLevel) override {
    if (batteryLevel < 20) {
      std::cout << "BatteryWarning: Warning - Battery level low (" << batteryLevel << "%)" << std::endl;
    }
  }
};

3.5.调用算法

cpp 复制代码
int main() {
  auto robot = std::make_shared<Robot>();
  auto batteryDisplay = std::make_shared<BatteryDisplay>();
  auto batteryWarning = std::make_shared<BatteryWarning>();

  robot->addObserver(batteryDisplay);
  robot->addObserver(batteryWarning);

  std::cout << "Setting battery level to 50%" << std::endl;
  robot->setBatteryLevel(50);

  std::cout << "\nSetting battery level to 15%" << std::endl;
  robot->setBatteryLevel(15);

  return 0;
}
相关推荐
二哈赛车手3 分钟前
新人笔记---多策略搭建策略执行链实现RAG检索后过滤
java·笔记·spring·设计模式·ai·策略模式
AI进化营-智能译站10 分钟前
ROS2 C++开发系列15-模板实现通用算法|宏定义ROS2调试开关|一次编码适配多平台
java·c++·算法·ai
澈20711 分钟前
C++引用与指针:核心区别全解析
开发语言·数据结构·c++
良木生香18 分钟前
【C++初阶】STL——Vector从入门到应用完全指南(1)
开发语言·c++·神经网络·算法·计算机视觉·自然语言处理·数据挖掘
Brilliantwxx19 分钟前
【C++】String的模拟实现(代码实现与坑点讲解)
开发语言·c++·笔记·算法
楼田莉子32 分钟前
仿Muduo的高并发服务器:Channel模块与Poller模块
linux·服务器·c++·学习·设计模式
zhouwy11333 分钟前
Linux网络编程从入门到精通
linux·c++
迷途之人不知返33 分钟前
deque的简单认识
数据结构·c++
zhouwy1131 小时前
C++ STL标准模板库详解
c++
li1670902701 小时前
第二十五章:C++11(下)
c语言·开发语言·数据结构·c++