C++ 设计模式:备忘录模式(Memento Pattern)

链接:C++ 设计模式
链接:C++ 设计模式 - 状态模式

备忘录模式(Memento Pattern)是一种行为设计模式,它允许在不破坏封装性的前提下捕获和恢复对象的内部状态。这个模式在需要保存和恢复对象状态的场景中非常有用,例如实现撤销操作。

1.问题分析

在开发中,有时需要保存对象的状态,以便在需要时恢复到之前的状态。这种需求在撤销/重做操作、游戏存档、编辑器状态恢复等场景中尤为常见。

备忘录模式通过将对象的状态封装在一个独立的备忘录对象中,实现了状态的保存和恢复,同时保持了对象的封装性。

2.实现步骤

  1. 定义备忘录类:存储对象的内部状态,
  2. 定义发起人类:负责创建和恢复备忘录。
  3. 定义管理者类:负责保存和管理备忘录对象。
  4. 客户端代码:实现保存状态到备忘录和从备忘录恢复状态。

3.代码示例

3.1.定义备忘录类

cpp 复制代码
// Memento类,负责存储机器人的状态
class Memento {
 public:
  Memento(int x, int y, const std::string& state) : x_(x), y_(y), state_(state) {}
  int getX() const { return x_; }
  int getY() const { return y_; }
  std::string getState() const { return state_; }

 private:
  int x_;
  int y_;
  std::string state_;
};

3.2.定义发起人类

cpp 复制代码
// Robot类,负责创建和恢复Memento
class Robot {
 public:
  void setPosition(int x, int y) {
    x_ = x;
    y_ = y;
    std::cout << "Position set to: (" << x << ", " << y << ")" << std::endl;
  }

  void setState(const std::string& state) {
    state_ = state;
    std::cout << "State set to: " << state << std::endl;
  }

  Memento saveStateToMemento() { return Memento(x_, y_, state_); }

  void getStateFromMemento(const Memento& memento) {
    x_ = memento.getX();
    y_ = memento.getY();
    state_ = memento.getState();
    std::cout << "State restored to: (" << x_ << ", " << y_ << "), " << state_ << std::endl;
  }

 private:
  int x_;
  int y_;
  std::string state_;
};

3.3.定义管理者类

cpp 复制代码
// Caretaker类,负责保存和恢复Memento
class Caretaker {
 public:
  void addMemento(const Memento& memento) { mementos_.push_back(memento); }

  Memento getMemento(int index) const { return mementos_.at(index); }

 private:
  std::vector<Memento> mementos_;
};

3.4.客户端代码

cpp 复制代码
int main() {
  Robot robot;
  Caretaker caretaker;

  robot.setPosition(0, 0);
  robot.setState("Idle");
  caretaker.addMemento(robot.saveStateToMemento());

  robot.setPosition(10, 20);
  robot.setState("Moving");
  caretaker.addMemento(robot.saveStateToMemento());

  robot.setPosition(30, 40);
  robot.setState("Stopped");

  robot.getStateFromMemento(caretaker.getMemento(0));
  robot.getStateFromMemento(caretaker.getMemento(1));

  return 0;
}
相关推荐
亦暖筑序14 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户8055336980317 小时前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
BadBadBad__AK1 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境2 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境2 天前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
郝学胜_神的一滴3 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
青禾网络3 天前
Web 前端如何接入 AI 音效生成:从零到可用的完整方案
人工智能·设计模式
ZJPRENO4 天前
吃透软件开发六大设计原则,告别烂代码
设计模式
咖啡八杯4 天前
GoF设计模式——命令模式
java·设计模式·架构
花椒技术4 天前
HJPusher / HJPlayer SDK 实践:我们为什么把直播推播链路拆成一套可复用能力
设计模式·harmonyos·直播