命令模式在Golang中通过接口和组合实现解耦,核心角色包括Command、ConcreteCommand、Receiver、Invoker和Client;示例以遥控器控制电灯展示开/关命令及扩展撤销功能,适用于参数化操作、队列执行、撤销重做与日志回放等场景。

在Golang中实现命令模式,可以将请求封装为独立对象,使发送者与接收者解耦。这种设计让操作可参数化、排队、记录日志或支持撤销。下面通过一个简单的示例说明如何用Go语言实现命令模式。
命令模式的核心结构
命令模式通常包含以下角色:
- Command(命令接口):定义执行操作的接口,比如 Execute()
- ConcreteCommand(具体命令):实现命令接口,持有接收者,并调用其方法
- Receiver(接收者):真正执行业务逻辑的对象
- Invoker(调用者):持有命令对象,触发命令执行
- Client(客户端):创建命令并绑定接收者
Go语言实现示例:遥控器控制设备
假设我们要实现一个遥控器控制电灯开关的功能:
// 接收者:电灯 type Light struct{} func (l *Light) On() { fmt.Println("电灯已打开") } func (l *Light) Off() { fmt.Println("电灯已关闭") } // 命令接口 type Command interface { Execute() } // 具体命令:开灯命令 type LightOnCommand struct { light *Light } func (c *LightOnCommand) Execute() { c.light.On() } // 具体命令:关灯命令 type LightOffCommand struct { light *Light } func (c *LightOffCommand) Execute() { c.light.Off() } // 调用者:遥控器 type RemoteControl struct { command Command } func (r *RemoteControl) PressButton() { r.command.Execute() }
客户端使用方式:
立即学习“go语言免费学习笔记(深入)”;
func main() {
light := &Light{}
onCommand := &LightOnCommand{light: light}
offCommand := &LightOffCommand{light: light}
remote := &RemoteControl{}
remote.command = onCommand
remote.PressButton() // 输出:电灯已打开
remote.command = offCommand
remote.PressButton() // 输出:电灯已关闭
}
扩展:支持多按钮和撤销操作
命令模式的优势在于易于扩展。例如添加撤销功能:
// 扩展命令接口支持撤销
type UndoableCommand interface {
Command
Undo()
}
func (c *LightOnCommand) Undo() {
c.light.Off()
}
func (c *LightOffCommand) Undo() {
c.light.On()
}
此时调用者也可记录历史命令,实现批量撤销:
type RemoteControlWithUndo struct {
command Command
history []UndoableCommand
}
func (r *RemoteControlWithUndo) PressButton() {
if cmd, ok := r.command.(UndoableCommand); ok {
cmd.Execute()
r.history = append(r.history, cmd)
}
}
func (r *RemoteControlWithUndo) Undo() {
if len(r.history) == 0 {
return
}
last := r.history[len(r.history)-1]
last.Undo()
r.history = r.history[:len(r.history)-1]
}
实际应用场景建议
命令模式适合以下场景:
- 需要参数化对象执行操作,如菜单项绑定动作
- 支持操作队列、延迟执行或网络传输命令
- 实现撤销/重做功能
- 日志记录操作以便恢复(如事务回放)
在Go中虽然没有类继承,但通过接口和组合能优雅实现命令模式。关键是将“动作”封装成对象,降低调用者与具体逻辑的耦合。
基本上就这些,不复杂但容易忽略细节。










