7. 命令模式

目录

一、解决的问题

  • 将行为请求者与行为实现者解耦,当用户发出命令后,无需关注谁来执行命令。
  • 将命令的发出者和命令的执行者完全隔离开。

二、设计类图

  • Client:创建具体的命令对象,并且设置命令对象的接收者
  • Invoker:命令传递者,要求命令对象执行请求
  • Command:定义命令的接口
  • ConcreteCommand:命令接口实现对象
  • Receiver:命令接收并执行

三、代码实现

3.1 设计类图

  • 以电视机遥控器作为背景进行,类图如下

3.2 代码实现

cpp 复制代码
#include <iostream>

class TV
{
private:
    int currentChannel = 0;

public:
    void changeChannel(int channel)
    {
        this->currentChannel = channel;
    }

    void turnOff()
    {
        std::cout << "TV is off." << std::endl;
    }

    void turnOn()
    {
        std::cout << "TV is on." << std::endl;
    }
};

class Command
{
public:
    virtual void execute() = 0;
};

class CommandOn : public Command
{
private:
    TV* myTV;
public:
    CommandOn(TV* tv)
    {
        myTV = tv;
    }

    void execute()
    {
        myTV->turnOn();
    }
};

class CommandOff : public Command
{
private:
    TV* myTV;
public:
    CommandOff(TV* tv)
    {
        myTV = tv;
    }

    void execute()
    {
        myTV->turnOff();
    }
};

class CommandChange : public Command
{
private:
    TV* myTV;
    int channel;
public:
    CommandChange(TV* tv, int channel)
    {
        myTV = tv;
        this->channel = channel;
    }

    void execute()
    {
        std::cout << "Switch Channel to " << channel << std::endl;
        myTV->changeChannel(channel);
    }
};

class Control
{
private:
    Command* changChannel;
    Command* offCommand;
    Command* onCommand;

public:
    Control(Command* changChannel, Command* off, Command* on)
    {
        this->changChannel = changChannel;
        this->offCommand = off;
        this->onCommand = on;
    }

    void changeChannel()
    {
        changChannel->execute();
    }
    
    void turnOff()
    {
        offCommand->execute();
    }

    void turnOn()
    {
        onCommand->execute();
    }
};

int main()
{
    TV* mytv = new TV();
    Command* on = new CommandOn(mytv);
    Command* off = new CommandOff(mytv);
    Command* channel = new CommandChange(mytv, 3);

    Control* control = new Control(channel, off, on);

    control->turnOn();
    control->changeChannel();
    control->turnOff();
    return 0;
}

四、扩展

  • 定义一个3对控制器的按钮
  • 分别控制客厅灯、厨房灯和车库门的开关操作
  • 类图如下
  • 运行结果
  • 代码部分请参阅 https://gitee.com/piglittle/design_patterns中的 Head_First_Design_Partterns解决方案下的 command_pattern项目
相关推荐
We་ct10 小时前
JS手撕:函数进阶 & 设计模式解析
开发语言·前端·javascript·设计模式·面试·前端框架
冷小鱼12 小时前
设计模式全景指南:23种模式深度解析与Python实现
设计模式
楼田莉子12 小时前
设计模式:创建型设计模式简介
服务器·开发语言·c++·设计模式
UrSpecial12 小时前
设计模式:观察者模式
观察者模式·设计模式
zhaoshuzhaoshu12 小时前
设计模式之结构型设计模式详解
python·设计模式
倒流时光三十年12 小时前
重学设计模式 之 流式 Builder 模式(Fluent Builder)
设计模式·流式 builder·fluent builder
IT枫斗者13 小时前
AI Agent 设计模式全景解析:从单体智能到分布式协作的架构演进
人工智能·redis·分布式·算法·spring·缓存·设计模式
UXbot1 天前
AI原型设计工具评测:从创意到交互式Demo,5款产品全面解析
前端·ui·设计模式·ai·ai编程·原型模式