当前位置: 首页 > news >正文

Python编码系列—Python备忘录模式:掌握对象状态保存与恢复技术

🌟🌟 欢迎来到我的技术小筑,一个专为技术探索者打造的交流空间。在这里,我们不仅分享代码的智慧,还探讨技术的深度与广度。无论您是资深开发者还是技术新手,这里都有一片属于您的天空。让我们在知识的海洋中一起航行,共同成长,探索技术的无限可能。

🚀 探索专栏:学步_技术的首页 —— 持续学习,不断进步,让学习成为我们共同的习惯,让总结成为我们前进的动力。

🔍 技术导航:

  • 人工智能:深入探讨人工智能领域核心技术。
  • 自动驾驶:分享自动驾驶领域核心技术和实战经验。
  • 环境配置:分享Linux环境下相关技术领域环境配置所遇到的问题解决经验。
  • 图像生成:分享图像生成领域核心技术和实战经验。
  • 虚拟现实技术:分享虚拟现实技术领域核心技术和实战经验。

🌈 非常期待在这个数字世界里与您相遇,一起学习、探讨、成长。不要忘了订阅本专栏,让我们的技术之旅不再孤单!

💖💖💖 ✨✨ 欢迎关注和订阅,一起开启技术探索之旅! ✨✨

文章目录

  • 1. 背景介绍
  • 2. 原理
  • 3. 使用场景
  • 4. 代码样例
  • 5. 实际应用案例
  • 6. 总结
      • 结语

1. 背景介绍

在软件编程中,能够保存和恢复对象的状态是一个常见需求,尤其是在需要实现撤销(Undo)功能的场景中。备忘录模式(Memento Pattern)允许在不破坏封装的前提下,捕获并保存一个对象的内部状态,并且可以恢复到先前的状态。本文将深入探讨Python中的备忘录模式,包括其背景、原理、使用场景、代码实现和实际应用案例。

备忘录模式是一种行为型设计模式,用于在不破坏对象的封装性的前提下,保存和恢复对象的状态。这种模式通常用于实现撤销功能,允许用户对操作进行回滚。
在这里插入图片描述

2. 原理

备忘录模式的核心原理包括:

  • 发起人(Originator):创建一个备忘录,用以记录当前时刻的内部状态,并可以利用该备忘录恢复内部状态。
  • 备忘录(Memento):负责存储发起人的当前状态,并可以防止其他对象访问。
  • 负责人(Caretaker):负责保存备忘录对象,但不能操作备忘录对象。

备忘录模式通过三个关键角色协同工作,提供了一种保存和恢复对象状态的机制,同时确保了对象的封装不受破坏。下面详细探讨备忘录模式的核心原理:

发起人(Originator)
发起人是需要被保存和恢复状态的对象。它定义了创建备忘录的方法,以及使用备忘录恢复状态的方法。发起人负责创建一个包含其当前状态的备忘录,并在需要时使用备忘录恢复其状态。发起人对自身的状态进行封装,确保备忘录中的状态数据是安全的。

class Originator:def __init__(self):self._state = Nonedef set_state(self, state):self._state = statedef get_state(self):return self._statedef save_to_memento(self):return Memento(self._state)def restore_from_memento(self, memento):self._state = memento._state

备忘录(Memento)
备忘录对象负责存储发起人的内部状态。备忘录通常包含发起人对象的私有数据,但它不会对外暴露这些数据。备忘录可以设计为只允许发起人对其进行读写操作,而其他对象只能对备忘录对象进行读取操作。

class Memento:def __init__(self, state):self._state = state

负责人(Caretaker)
负责人负责管理备忘录对象,它可能包含对备忘录的保存、删除等操作,但不会对备忘录中存储的状态数据进行任何操作。负责人可以保存多个备忘录对象,并且可以在需要时将它们提供给发起人进行状态恢复。

class Caretaker:def __init__(self):self._mementos = []def save_memento(self, memento):self._mementos.append(memento)def get_memento(self, index):return self._mementos[index]

通过这三个核心组件的协同工作,备忘录模式实现了以下目标:

  1. 封装性:发起人对象的内部状态被封装在备忘录对象中,外部对象无法直接访问这些状态。
  2. 撤销操作:通过备忘录对象,发起人对象可以恢复到之前的状态,实现了撤销操作。
  3. 解耦:发起人对象不需要知道备忘录对象是如何存储或管理状态的,实现了发起人对象与负责人对象之间的解耦。

备忘录模式非常适合于需要实现撤销/重做功能的系统,如文本编辑器、图形编辑器等。通过使用备忘录模式,可以在不破坏对象封装性的前提下,灵活地保存和恢复对象的状态。

3. 使用场景

备忘录模式适用于以下场景:

  • 需要保存和恢复对象的历史状态:如文本编辑器的撤销/重做功能。
  • 需要实现撤销操作但不希望破坏对象的封装性

4. 代码样例

以下是一个Python中实现备忘录模式的示例:

class Memento:def __init__(self, state):self._state = stateclass Originator:def __init__(self):self._state = Nonedef set_state(self, state):self._state = stateprint(f"Originator: My state is '{self._state}'")def get_state(self):return self._statedef save_to_memento(self):return Memento(self._state)def restore_from_memento(self, memento):self._state = memento._stateprint(f"Originator: My state has changed to '{self._state}'")class Caretaker:def __init__(self):self._mementos = []def save_memento(self, memento):self._mementos.append(memento)def get_memento(self, index):return self._mementos[index]# 客户端代码
if __name__ == "__main__":originator = Originator()originator.set_state("State 1")caretaker = Caretaker()caretaker.save_memento(originator.save_to_memento())originator.set_state("State 2")caretaker.save_memento(originator.save_to_memento())originator.restore_from_memento(caretaker.get_memento(0))originator.restore_from_memento(caretaker.get_memento(1))

5. 实际应用案例

假设我们正在开发一个图形编辑软件,需要允许用户撤销和重做他们对图形对象的修改。我们可以使用备忘录模式来实现这一需求。

class GraphicEditor:def __init__(self):self._states = []def save_state(self):state = self.get_current_state()memento = Memento(state)self._states.append(memento)print(f"Saved state: {state}")def undo(self):if self._states:memento = self._states.pop()self.restore_state(memento)print(f"Undid state to: {self.get_current_state()}")def get_current_state(self):# Implementation of getting current statepassdef restore_state(self, memento):# Implementation of restoring statepass# 客户端代码
if __name__ == "__main__":editor = GraphicEditor()editor.save_state()editor.save_state()editor.undo()editor.undo()

6. 总结

备忘录模式是一种非常实用的设计模式,它允许在不破坏对象封装性的前提下,捕获并保存对象的状态,并且可以恢复到先前的状态。这种模式在实现撤销/重做功能时非常有用。

结语

设计模式是软件设计中的艺术,备忘录模式作为其中的一种,为我们提供了一种优雅的方式来保存和恢复对象的状态。希望本文能够帮助你在Python项目中更好地应用备忘录模式,提升代码的质量和灵活性。

🌟 在这篇博文的旅程中,感谢您的陪伴与阅读。如果内容对您有所启发或帮助,请不要吝啬您的点赞 👍🏻,这是对我最大的鼓励和支持。

📚 本人虽致力于提供准确且深入的技术分享,但学识有限,难免会有疏漏之处。如有不足或错误,恳请各位业界同仁在评论区留下宝贵意见,您的批评指正是我不断进步的动力!😄😄😄

💖💖💖 如果您发现这篇博文对您的研究或工作有所裨益,请不吝点赞、收藏,或分享给更多需要的朋友,让知识的力量传播得更远。

🔥🔥🔥 “Stay Hungry, Stay Foolish” —— 求知的道路永无止境,让我们保持渴望与初心,面对挑战,勇往直前。无论前路多么漫长,只要我们坚持不懈,终将抵达目的地。🌙🌙🌙

👋🏻 在此,我也邀请您加入我的技术交流社区,共同探讨、学习和成长。让我们携手并进,共创辉煌!
在这里插入图片描述

相关文章:

  • HTTP请求中GET与POST方法的核心区别与用途解析
  • VMware下的ubuntu显示文字太小的自适应显示调整
  • 力扣题解2286
  • 【高分系列卫星简介——高分五号卫星(GF-5)】
  • Jenkins入门:从搭建到部署第一个Springboot项目(踩坑记录)
  • 【NodeJS】npm、yarn、pnpm当前项目设置国内镜像源
  • 【算法】分治:归并排序之LCR 170.交易逆序对的总数(hard)
  • linux脚本工具
  • 【Godot4.3】简单物理模拟之圆粒子碰撞检测
  • 【Java】虚拟机(JVM)内存模型全解析
  • RM服务器研究(一)
  • SpringBoot3.X配置OAuth
  • vLLM (6) - Scheduler BlockSpaceManager
  • 数据结构:栈 及其应用
  • 多元函数微分学基础题
  • JS 中的深拷贝与浅拷贝
  • 【技术性】Search知识
  • Angular数据绑定机制
  • Apache Zeppelin在Apache Trafodion上的可视化
  • Go 语言编译器的 //go: 详解
  • JavaScript异步流程控制的前世今生
  • PHP的Ev教程三(Periodic watcher)
  • Service Worker
  • SpiderData 2019年2月25日 DApp数据排行榜
  • Spring核心 Bean的高级装配
  • 力扣(LeetCode)965
  • 聊聊flink的BlobWriter
  • 前端存储 - localStorage
  • 前端相关框架总和
  • 前端性能优化--懒加载和预加载
  • 悄悄地说一个bug
  • 为物联网而生:高性能时间序列数据库HiTSDB商业化首发!
  • 学习HTTP相关知识笔记
  • 【运维趟坑回忆录】vpc迁移 - 吃螃蟹之路
  • puppet连载22:define用法
  • 如何在招聘中考核.NET架构师
  • ​​​【收录 Hello 算法】10.4 哈希优化策略
  • #APPINVENTOR学习记录
  • #NOIP 2014# day.1 T3 飞扬的小鸟 bird
  • $redis-setphp_redis Set命令,php操作Redis Set函数介绍
  • (6)【Python/机器学习/深度学习】Machine-Learning模型与算法应用—使用Adaboost建模及工作环境下的数据分析整理
  • (C#)Windows Shell 外壳编程系列4 - 上下文菜单(iContextMenu)(二)嵌入菜单和执行命令...
  • (C语言)编写程序将一个4×4的数组进行顺时针旋转90度后输出。
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo
  • (独孤九剑)--文件系统
  • (多级缓存)多级缓存
  • (附源码)计算机毕业设计SSM智慧停车系统
  • (几何:六边形面积)编写程序,提示用户输入六边形的边长,然后显示它的面积。
  • (精确度,召回率,真阳性,假阳性)ACC、敏感性、特异性等 ROC指标
  • (离散数学)逻辑连接词
  • (六) ES6 新特性 —— 迭代器(iterator)
  • (六)软件测试分工
  • (收藏)Git和Repo扫盲——如何取得Android源代码
  • (一)面试需要掌握的技巧
  • .bat批处理(二):%0 %1——给批处理脚本传递参数