首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
备忘录模式如何实现对象状态回滚与撤销功能

备忘录模式如何实现对象状态回滚与撤销功能

热心网友
96
转载
2026-05-10

在软件设计中实现撤销与恢复功能时,开发者通常会考虑全局历史记录或复杂的状态追踪。然而,备忘录模式(Memento Pattern)提供了一种更为优雅和封装性更强的解决方案。其核心理念可概括为“状态快照”与“隔离恢复”——即由对象自身负责其内部状态的备份与还原,而外部实体仅扮演快照保管者的角色,无权直接访问或修改状态内容。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

备忘录模式(Memento)撤销机制:实现对象变量状态的回滚功能

发起人(Originator):状态生命周期的唯一管理者

对象的状态是其核心私有数据,若允许外部直接访问,将彻底破坏封装原则。因此,发起人对象需对外提供两个关键方法:

  • createMemento():在状态发生变更前调用。此方法的核心在于执行深拷贝操作——无论是使用 Python 的 copy.deepcopy、Java 中创建全新对象实例,还是 Go 语言中显式复制切片与 map——以生成一份完全独立且只读的状态快照。
  • restoreFromMemento(memento):此方法职责单一,即从传入的备忘录对象中提取保存的状态值,并将其安全地赋值回自身的内部字段。整个过程不暴露字段细节,且确保外部无法修改备忘录内容。

备忘录(Memento):实现真正不可变与封装的状态快照

备忘录并非简单的数据容器,而更像一个密封的保险箱,内部封装了特定时刻的完整对象状态:

  • 字段完全私有化:在 Java 或 C# 中使用 private final 修饰;在 Go 中采用小写字母开头的未导出字段;在 Python 中则依赖约定与深拷贝机制共同保障。
  • 提供受控的访问接口:通常仅向发起人暴露一个如 getSavedState() 的方法,且返回值应为不可变类型(如 String、ImmutableList)或其副本,以防止外部通过引用意外篡改快照数据。
  • 严格限制构造权限:备忘录的构造函数应仅对发起人对象开放。这可通过 Java 的包访问权限、C++ 的 friend 声明或 Go 的同包可见性机制来实现,确保状态管理者无法私自创建或修改备忘录实例。

管理者(Caretaker):专注存储中转,不涉及状态语义

管理者的角色极为纯粹,如同一个编号归档的仓库管理员:

  • 使用栈、列表或数组等结构保存多个备忘录实例,以支持多步撤销与重做功能。
  • 提供 push(memento)pop()get(index) 等基础存取方法。但必须注意,管理者绝不应调用备忘录的获取状态方法,也无需理解状态的具体含义。
  • 其职责严格限定于存储与提供备忘录对象,不参与状态逻辑校验、快照合并或序列化等业务操作——所有与状态相关的业务逻辑都应封装在发起人对象内部。

状态回滚:确保粒度一致性与数据完整性

撤销操作的最大风险在于状态不一致。一次完整的回滚必须还原所有关联变量,避免部分状态遗漏:

  • 例如,在文本编辑器中进行撤销时,若仅恢复了文本内容而忽略了光标位置与选中区域,将导致用户体验断裂。同样,在恢复游戏角色状态时,必须同时回滚生命值、魔法值、技能冷却时间等所有关联属性。
  • 实用建议是:将逻辑上紧密关联的变量组合封装进同一个备忘录对象。例如 EditorMemento(content, cursorPosition, selectionRange)
  • 此外,若变量间存在计算依赖关系(如总价 = 单价 × 数量),应在发起人内部保存原始的、独立的字段值,而非存储计算后的衍生值。如此才能在恢复时确保基础逻辑的正确性与一致性。

总结而言,备忘录模式通过清晰的职责分离——发起人负责状态的生成与解析,备忘录负责封装不可变快照,管理者负责纯粹的存储管理——构建了一种既安全又灵活的状态回滚机制。该模式将状态变化的可能性封装在对象内部,同时对外提供简洁稳定的接口,充分体现了高内聚、低耦合的优秀软件设计原则。

来源:https://www.php.cn/faq/2450923.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

工信部启动人工智能伦理审查先导计划规范AI发展
科技数码
工信部启动人工智能伦理审查先导计划规范AI发展

工信部启动人工智能科技伦理审查与服务先导计划,推动治理办法在重点区域实施。计划将细化省级审查规范,指导设立伦理委员会,建设服务中心支持中小企业,建立风险报送预警机制和全国监测网络,并通过培训加强人才队伍建设,系统性提升产业伦理风险应对能力。

热心网友
05.10
微信输入法电脑手机版更新 隔空传送文件无需流量秒传
科技数码
微信输入法电脑手机版更新 隔空传送文件无需流量秒传

微信输入法最近动作频频。继去年底在iOS端迎来3 0大版本更新后,日前其Windows和iOS双端又同步推送了新版本。这次更新的核心看点,是一个名为“隔空传送”的功能正式上线。 简单来说,这个功能允许用户在多个设备之间,快速传输图片、视频和各类文件。更实用的一点是,它支持通过扫码与他人建立连接,实现

热心网友
05.10
头号禁区手游快速赚钱攻略与高效盈利方法详解
游戏资讯
头号禁区手游快速赚钱攻略与高效盈利方法详解

在《头号禁区》这类手游里,快速积累财富往往是玩家最关心的话题之一。这过程确实不轻松,但绝非无章可循。只要方法得当,游戏内的经济系统完全可以为你所用,让金币和资源稳步增长。 完成主线与支线任务 最稳定、最基础的资金来源,莫过于游戏的主线与支线任务。它们不仅是推动剧情的关键,更是设计好的“新手福利”与“

热心网友
05.10
2026年炉石传说德鲁伊最强卡组搭配推荐
游戏资讯
2026年炉石传说德鲁伊最强卡组搭配推荐

在2026年的炉石传说天梯环境中,德鲁伊卡组以其卓越的节奏掌控能力脱颖而出。这套卡组的核心并非依赖单张终结牌,而是通过精密的场面运营与资源循环,从对局伊始便逐步累积优势,最终在持续的压制中锁定胜局。 核心单卡解析 一套卡组的强度,往往由几张核心卡牌决定。对于这套德鲁伊而言,以下几张牌是构筑其战术体系

热心网友
05.10
币安Binance官方APP下载注册与使用全攻略
web3.0
币安Binance官方APP下载注册与使用全攻略

本文详细介绍了如何安全下载并注册必安Binance应用程序。内容涵盖从官方渠道获取安装包、完成账户注册与身份验证的完整步骤,并提供了新用户上手的基础操作指引。同时,文中强调了在整个过程中保护账户安全、防范网络钓鱼等关键注意事项,旨在帮助用户顺利开启数字资产交易之旅。

热心网友
05.10