命令模式在C++中通过将请求封装为Command接口对象实现解耦,支持参数化、排队、日志与撤销;Invoker调用execute()/undo()而不依赖Receiver细节,Receiver仅执行具体逻辑,命令对象应轻量、无状态或仅存必要上下文,撤销需缓存状态并用智能指针管理生命周期。

命令模式在C++中核心是把“请求”封装成对象,从而支持参数化、排队、日志、撤销等操作。关键在于定义统一的命令接口,让调用者(Invoker)不依赖具体操作细节,而接收者(Receiver)只负责执行实际逻辑。
命令接口与具体命令类
定义抽象基类 Command,声明虚函数 execute() 和可选的 undo();每个具体操作(如打开文件、保存、撤回)派生一个命令类,内部持有对 Receiver 的引用或所需数据。
- Receiver 不直接被 Invoker 调用,而是由 Command 在 execute() 中调用其方法
- 命令对象应尽量无状态,或仅保存执行必需的最小上下文(如文件名、旧文本、坐标)
- 若需撤销,undo() 必须能恢复到 execute 前的状态,通常需在 execute 中缓存关键信息
支持撤销的命令栈管理
用 std::stack<:unique_ptr>> 管理已执行命令,每次 execute 后压入栈;调用 undo 时弹出栈顶并调用其 undo()。注意:不是所有命令都支持撤销(如“退出程序”),可加 isUndoable() 接口或用空实现。
- 撤销后通常需禁用重做(Redo),若需支持,可额外维护一个 redo 栈,在 undo 时把命令移入 redo 栈
- 避免裸指针,用智能指针管理命令生命周期,防止内存泄漏
- 命令对象一般是一次性使用的,执行/撤销后可析构,无需复用
调用者(Invoker)解耦设计
Invoker 持有 Command* 或 std::function
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~