备忘录模式如何实现对象状态回滚与撤销功能
在软件设计中实现撤销与恢复功能时,开发者通常会考虑全局历史记录或复杂的状态追踪。然而,备忘录模式(Memento Pattern)提供了一种更为优雅和封装性更强的解决方案。其核心理念可概括为“状态快照”与“隔离恢复”——即由对象自身负责其内部状态的备份与还原,而外部实体仅扮演快照保管者的角色,无权直接访问或修改状态内容。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

发起人(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)。 - 此外,若变量间存在计算依赖关系(如总价 = 单价 × 数量),应在发起人内部保存原始的、独立的字段值,而非存储计算后的衍生值。如此才能在恢复时确保基础逻辑的正确性与一致性。
总结而言,备忘录模式通过清晰的职责分离——发起人负责状态的生成与解析,备忘录负责封装不可变快照,管理者负责纯粹的存储管理——构建了一种既安全又灵活的状态回滚机制。该模式将状态变化的可能性封装在对象内部,同时对外提供简洁稳定的接口,充分体现了高内聚、低耦合的优秀软件设计原则。
热门专题
热门推荐
工信部启动人工智能科技伦理审查与服务先导计划,推动治理办法在重点区域实施。计划将细化省级审查规范,指导设立伦理委员会,建设服务中心支持中小企业,建立风险报送预警机制和全国监测网络,并通过培训加强人才队伍建设,系统性提升产业伦理风险应对能力。
微信输入法最近动作频频。继去年底在iOS端迎来3 0大版本更新后,日前其Windows和iOS双端又同步推送了新版本。这次更新的核心看点,是一个名为“隔空传送”的功能正式上线。 简单来说,这个功能允许用户在多个设备之间,快速传输图片、视频和各类文件。更实用的一点是,它支持通过扫码与他人建立连接,实现
在《头号禁区》这类手游里,快速积累财富往往是玩家最关心的话题之一。这过程确实不轻松,但绝非无章可循。只要方法得当,游戏内的经济系统完全可以为你所用,让金币和资源稳步增长。 完成主线与支线任务 最稳定、最基础的资金来源,莫过于游戏的主线与支线任务。它们不仅是推动剧情的关键,更是设计好的“新手福利”与“
在2026年的炉石传说天梯环境中,德鲁伊卡组以其卓越的节奏掌控能力脱颖而出。这套卡组的核心并非依赖单张终结牌,而是通过精密的场面运营与资源循环,从对局伊始便逐步累积优势,最终在持续的压制中锁定胜局。 核心单卡解析 一套卡组的强度,往往由几张核心卡牌决定。对于这套德鲁伊而言,以下几张牌是构筑其战术体系
本文详细介绍了如何安全下载并注册必安Binance应用程序。内容涵盖从官方渠道获取安装包、完成账户注册与身份验证的完整步骤,并提供了新用户上手的基础操作指引。同时,文中强调了在整个过程中保护账户安全、防范网络钓鱼等关键注意事项,旨在帮助用户顺利开启数字资产交易之旅。





