快照模式 vs 命令模式:一篇分清什么时候用谁

在做带撤销、回滚、历史记录的功能时,我们最常纠结两个设计模式:快照模式(备忘录模式)命令模式 。很多同学容易混淆,其实核心区别一句话就能记住:
快照存数据,命令存动作。

下面用最清晰、最好记的方式,对比两者适用场景,看完就能直接选型。


一、快照模式(存数据 / 状态)

适合场景:

  • 状态简单、操作少
  • 不想写复杂的反向 undo 逻辑
  • 状态结构很轻量(比如一个数字、一段短文本)
  • 不需要精细撤销,只想一键回到某一刻
  • 对内存占用不太敏感,存档即可

典型使用场景:

  • 游戏存档/读档
  • 配置文件一键恢复
  • 简单文本编辑器的整体撤销

一句话总结:
状态小、懒得写反向 → 快照


二、命令模式(存动作 / 操作)

适合场景:

  • 操作种类多(增、删、改、拖、画等)
  • 需要一步步撤销 / 重做
  • 状态体积大(图片、大型文档、画布),频繁存快照太占内存
  • 需要记录操作日志、任务队列、宏命令

典型使用场景:

  • Photoshop、Figma、画板工具
  • IDE 代码编辑器 Ctrl+Z
  • 复杂表单操作历史
  • 支持宏命令、任务队列的系统

一句话总结:
操作多、状态大、要精细撤销 → 命令


三、终极口诀(记住就够)

  • 状态小、懒得写反向 → 快照
  • 操作多、状态大、要精细撤销 → 命令

理解到这一步,面试、日常开发选型都能说得清清楚楚,再也不会纠结用哪个了。

相关推荐
2301_764441333 小时前
Dify工作流中实现查询优化(QO):将查询复杂度分类法与QOL框架融入工作流
人工智能·语言模型·自然语言处理·命令模式
fe7tQnVan6 小时前
三大 Agent-UI 协议深度剖析:AG-UI、A2UI 与 MCP-UI 的设计哲学与工程实践
ui·状态模式·命令模式
程序员小寒2 天前
JavaScript设计模式(八):命令模式实现与应用
前端·javascript·设计模式·ecmascript·命令模式
砍光二叉树5 天前
【设计模式】行为型-命令模式
设计模式·命令模式
心前阳光8 天前
UI在指定区域内拖拽
ui·命令模式
青春易逝丶8 天前
命令模式
命令模式
lierenvip10 天前
SpringDoc和Swagger使用
命令模式
Anurmy20 天前
设计模式之命令模式
设计模式·命令模式
蜜獾云22 天前
设计模式之命令模式:给其他模块下达命令
设计模式·命令模式