当前位置: 首页 > news >正文

命令模式简介

概念

命令模式是一种行为设计模式,它将请求封装成一个对象,从而允许您将不同的请求参数化、队列化,并且能够在不同的时间点执行。通过引入命令对象(Command)来解耦发送者(Invoker)和接收者(Receiver),使得发送者无需知道具体的接收者或操作细节。命令对象封装了一系列操作,并提供了一个统一的方法(如execute()),以便调用这些操作。

特点

  1. 解耦性:命令模式将发送者与接收者之间解耦,使得它们可以独立演化。
  2. 可扩展性:可以方便地添加新的命令类和接收类,而无需修改现有代码。
  3. 可撤销/重做:由于每个命令都包含了执行和撤销操作,因此可以轻松地实现撤销、重做等功能。
  4. 容易组合:多个简单命令可以组合成复杂命令,在需要时进行灵活组合。

优点

  1. 降低系统的耦合度。发送者与接收者之间不存在直接关联关系。
  2. 更好地支持撤销、重做等功能。每个具体命令断言了相关操作及其撤销操作。
  3. 更好地支持日志和事务。可以记录命令的执行过程,以及在需要时进行回滚。

缺点

  1. 可能会导致类爆炸。每个具体命令都需要一个对应的接收者类。
  2. 命令模式增加了系统的复杂性,因为它引入了额外的抽象层次。

适用场景

  1. 需要将请求参数化、队列滑,并希望能够在不同时间执行。
  2. 需要支持撤销、重做等功能。
  3. 需要实现日志记录、事务管理等功能。

实现方式

  1. 定义一个抽象命令(Command)接口或抽象类,其中包含一个execute()方法用于执行命令。
  2. 创建具体命令类,实现抽象命令接口或继承抽象命令类,并在其中编写具体操作逻辑及其撤销逻辑。
  3. 定义接收者(Receiver)类,该类包含真正执行操作的方法。
  4. 创建调用者(Invoker)对象,在其中维护一系列命令对象,并通过调用execute()方法来触发相应的操作。

实现代码

import java.util.ArrayList;
import java.util.List;// 抽象命令接口
interface Command {void execute();
}// 具体命令类1
class ConcreteCommand1 implements Command {private Receiver receiver;public ConcreteCommand1(Receiver receiver) {this.receiver = receiver;}@Overridepublic void execute() {receiver.action1();}
}// 具体命令类2
class ConcreteCommand2 implements Command {private Receiver receiver;public ConcreteCommand2(Receiver receiver) {this.receiver = receiver;}@Overridepublic void execute() {receiver.action2();}
}// 接收者类
class Receiver {public void action1() {System.out.println("执行操作1");}public void action2() {System.out.println("执行操作2");}
}// 调用者类/发送者类/Invoker类
class Invoker {private List<Command> commands = new ArrayList<>();// 添加命令到队列中public void addCommand(Command command) {commands.add(command);}// 执行所有的命令public void executeCommands() {for (Command command : commands) {command.execute();}commands.clear(); // 清空已执行的命令列表,可选操作。}
}public class Main {public static void main(String[] args) {// 创建接收者对象Receiver receiver = new Receiver();// 创建具体命令对象并指定接收者Command command1 = new ConcreteCommand1(receiver);Command command2 = new ConcreteCommand2(receiver);// 创建调用者对象,并添加命令到队列中Invoker invoker = new Invoker();invoker.addCommand(command1);invoker.addCommand(command2);// 执行所有命令invoker.executeCommands();}}

在上述代码中,我们定义了一个抽象的Command接口,其中包含了一个execute()方法。然后创建了两个具体的命令类:ConcreteCommand1`ConcreteCommand2,它们实现了Command接口并重写了execute()`方法。这些具体的命令类将调用接收者类中的不同操作。

在接收者类中,我们定义了两个操作:action1()action2()

最后,我们创建了一个调用者类/发送者类/Invoker类。它维护一个命令队列,并提供添加命令和执行所有命令的方法。当调用执行所有命令的方法时,它会依次执行每个命令。

通过使用命令模式,可以将请求发送方与接收方解耦,并且可以轻松地添加新的具体命令而无需修改现有代码。此外,由于每个具体的命令都是独立封装的对象,因此可以轻松地进行参数化配置和传递。

http://www.lryc.cn/news/173816.html

相关文章:

  • Boost序列化指针
  • NIO简单介绍
  • linux进程杀不死
  • 5分钟带你搞懂RPA到底是什么?RPA能做什么?
  • 毫米波雷达 TI IWR1443 在 ROS 中进行 octomap 建图
  • 113双周赛
  • React 全栈体系(九)
  • 阈值化分割,对灰度级图像进行二值化处理(数字图像处理大题复习 P8)
  • vue3中withDefaults是什么
  • Android进阶之路 - 盈利、亏损金额格式化
  • 工业蒸汽量预测(速通一)
  • 机器学习的主要内容
  • 华为OD机试真题-分积木-2023年OD统一考试(B卷)
  • SpringBoot自动装配原理及分析
  • Android开发笔记 :理解Fragment
  • std::chrono获取当前秒级/毫秒级/微秒级/纳秒级时间戳
  • sh文件介绍及linux下执行
  • js-cookie使用 js深度克隆(判断引用类型是数组还是对象的方法)
  • [Pytorch]语义分割任务分类的实现
  • 测试网页调用本地可执行程序(续:带参数调用)
  • Carla自动驾驶模拟器安装和使用
  • 【每日一题】1539. 第 k 个缺失的正整数
  • AI-Chat,一款集全网ai功能的应用(附下载链接)
  • 3、靶场——Pinkys-Place v3(3)
  • 什么是 AirServer?Mac专用投屏工具AirServer 7 .27 for Mac中文破解版百度网盘下载
  • MapStruct介绍以及VO、DTO、PO、DO的区别
  • 记一次hyperf框架封装swoole自定义进程
  • 多输入多输出 | MATLAB实现GA-BP遗传算法优化BP神经网络多输入多输出
  • 李宏毅机器学习笔记-transformer
  • 基于Java的酒店管理系统