Python编码系列—Python命令模式:将请求封装为对象

🌟🌟 欢迎来到我的技术小筑,一个专为技术探索者打造的交流空间。在这里,我们不仅分享代码的智慧,还探讨技术的深度与广度。无论您是资深开发者还是技术新手,这里都有一片属于您的天空。让我们在知识的海洋中一起航行,共同成长,探索技术的无限可能。

🚀 探索专栏:学步_技术的首页 —— 持续学习,不断进步,让学习成为我们共同的习惯,让总结成为我们前进的动力。

🔍 技术导航:

  • 人工智能:深入探讨人工智能领域核心技术。
  • 自动驾驶:分享自动驾驶领域核心技术和实战经验。
  • 环境配置:分享Linux环境下相关技术领域环境配置所遇到的问题解决经验。
  • 图像生成:分享图像生成领域核心技术和实战经验。
  • 虚拟现实技术:分享虚拟现实技术领域核心技术和实战经验。

🌈 非常期待在这个数字世界里与您相遇,一起学习、探讨、成长。不要忘了订阅本专栏,让我们的技术之旅不再孤单!

💖💖💖 ✨✨ 欢迎关注和订阅,一起开启技术探索之旅! ✨✨

文章目录

  • 1. 背景介绍
  • 2. 原理
  • 3. 使用场景
  • 4. 代码样例
  • 5. 实际应用案例
  • 6. 总结

1. 背景介绍

在软件设计中,我们经常需要对操作进行封装、记录、排队或日志记录等处理。命令模式(Command Pattern)提供了一种将请求封装为一个对象的方法,从而可以用不同的请求对客户进行参数化,同时支持可撤销的操作。本文将深入探讨Python中的命令模式,包括其背景、原理、使用场景、代码实现和实际应用案例。

命令模式是一种行为型设计模式,它将一个请求封装为一个对象,从而允许用户使用不同的请求、队列或日志请求来参数化其他对象。命令模式也支持可撤销的操作。
在这里插入图片描述

2. 原理

命令模式的核心原理包括:

  • 定义命令接口:定义命令的接口,包含执行命令的方法。
  • 创建具体命令:实现命令接口,对应于具体的行为和接收者。
  • 实现调用者:调用命令对象的执行方法。
  • 创建客户端:创建具体命令对象,并设置其接收者。

命令模式通过将操作的请求者和操作的执行者解耦,提高了系统的灵活性和可扩展性。下面是命令模式核心原理的详细解释:

定义命令接口
命令接口是所有具体命令的抽象,它定义了所有命令类必须遵守的execute方法。这个接口充当了命令的模板,确保了所有的命令都能够以统一的方式被调用。

class Command:def execute(self):pass

在这个例子中,Command类定义了命令接口,其中包含execute方法,该方法将在具体命令中被实现。

创建具体命令
具体命令类实现了命令接口,并封装了接收者和执行操作所需的所有信息。每个具体命令对象都对应于一个具体的行为,它将接收者与行为绑定在一起。

class ConcreteCommandA(Command):def __init__(self, receiver):self._receiver = receiverdef execute(self):self._receiver.action()

在这个例子中,ConcreteCommandA类实现了Command接口,并在execute方法中调用了接收者对象的action方法。

实现调用者
调用者持有命令对象的引用,并在某个时刻执行命令。调用者不直接与接收者交互,而是通过命令对象来间接发出请求,这样调用者就不必知道接收者的具体实现细节。

class Invoker:def __init__(self):self._command = Nonedef set_command(self, command):self._command = commanddef execute_command(self):if self._command:self._command.execute()

在这个例子中,Invoker类定义了一个execute_command方法,该方法执行已设置的命令对象。

创建客户端
客户端负责创建具体命令对象,并且将命令对象与接收者关联。客户端可以动态地将不同的命令对象和接收者对象进行组合,从而创建出不同的请求。

# 客户端代码
receiver = Receiver()
command = ConcreteCommandA(receiver=receiver)
invoker = Invoker()
invoker.set_command(command)
invoker.execute_command()

在这个例子中,客户端创建了一个Receiver对象和一个ConcreteCommandA对象,然后将Receiver对象传递给ConcreteCommandA对象,并设置到Invoker对象中。

通过这些核心原理,命令模式使得请求发送者和接收者之间实现了完全解耦,增加了灵活性,使得系统更容易扩展和维护。这种模式在需要对操作进行记录、撤销或重做的场景中非常有用。

3. 使用场景

命令模式适用于以下场景:

  • 需要将操作封装为对象:例如,需要记录操作历史或支持撤销/重做功能。
  • 需要解耦发起操作的对象和执行操作的对象:提高系统的灵活性。
  • 需要支持事务和批处理操作:将多个操作组合在一起执行。

4. 代码样例

以下是一个Python中实现命令模式的示例:

from abc import ABC, abstractmethod# 定义命令接口
class Command(ABC):@abstractmethoddef execute(self):pass# 创建具体命令
class Light:def switch_on(self):print("Light is on")def switch_off(self):print("Light is off")class SwitchOnCommand(Command):def __init__(self, light):self._light = lightdef execute(self):self._light.switch_on()class SwitchOffCommand(Command):def __init__(self, light):self._light = lightdef execute(self):self._light.switch_off()# 实现调用者
class RemoteControl:def __init__(self):self._command = Nonedef set_command(self, command):self._command = commanddef press_button(self):if self._command:self._command.execute()# 客户端代码
if __name__ == "__main__":light = Light()on_command = SwitchOnCommand(light)off_command = SwitchOffCommand(light)remote = RemoteControl()remote.set_command(on_command)remote.press_button()  # Output: Light is onremote.set_command(off_command)remote.press_button()  # Output: Light is off

5. 实际应用案例

假设我们正在开发一个文本编辑器,需要实现文本的撤销和重做功能。我们可以使用命令模式来实现这一需求。

class TextEditor:def __init__(self):self._content = ""self._history = []def type(self, text):self._content += textprint(f"Current content: {self._content}")def undo(self):if self._history:self._content = self._history.pop()print(f"Content after undo: {self._content}")class Document:def __init__(self):self._editors = []def add_editor(self, editor):self._editors.append(editor)def remove_editor(self, editor):self._editors.remove(editor)def execute_command(self, command):command.execute()self._history.append(command._content)class TypeCommand(Command):def __init__(self, document, text):self._document = documentself._text = textself._content = document._contentdef execute(self):editor = TextEditor()editor.type(self._text)self._document.execute_command(self)def undo(self):editor = TextEditor()editor.undo()# 客户端代码
if __name__ == "__main__":doc = Document()command = TypeCommand(doc, "Hello, World!")command.execute()command.undo()

6. 总结

命令模式是一种非常实用的设计模式,它通过将请求封装为对象,允许用户使用不同的请求对客户进行参数化,同时支持可撤销的操作。这种模式在处理需要记录操作历史、支持撤销/重做功能的场景中非常有用。

设计模式是软件设计中的艺术,命令模式作为其中的一种,为我们提供了一种灵活的方式来封装操作。希望本文能够帮助你在Python项目中更好地应用命令模式,提升代码的质量和灵活性。

🌟 在这篇博文的旅程中,感谢您的陪伴与阅读。如果内容对您有所启发或帮助,请不要吝啬您的点赞 👍🏻,这是对我最大的鼓励和支持。

📚 本人虽致力于提供准确且深入的技术分享,但学识有限,难免会有疏漏之处。如有不足或错误,恳请各位业界同仁在评论区留下宝贵意见,您的批评指正是我不断进步的动力!😄😄😄

💖💖💖 如果您发现这篇博文对您的研究或工作有所裨益,请不吝点赞、收藏,或分享给更多需要的朋友,让知识的力量传播得更远。

🔥🔥🔥 “Stay Hungry, Stay Foolish” —— 求知的道路永无止境,让我们保持渴望与初心,面对挑战,勇往直前。无论前路多么漫长,只要我们坚持不懈,终将抵达目的地。🌙🌙🌙

👋🏻 在此,我也邀请您加入我的技术交流社区,共同探讨、学习和成长。让我们携手并进,共创辉煌!
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/880835.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【软件测试】详解软件测试中的测试级别

目录 一、测试级别二、组件测试三、开发者测试3.1测试与调试3.2 组件测试目标3.3 测试功能 四、稳健性测试4.1 效率的测试4.2 测试可维护性4.3 测试策略4.4 白盒测试 一、测试级别 软件系统通常是由许多子系统组成的,而这些子系统又是由多个组件组成的,…

VMware Aria Operations for Logs 8.18 发布,新增功能概览

VMware Aria Operations for Logs 8.18 - 集中式日志管理 请访问原文链接:https://sysin.org/blog/vmware-aria-operations-for-logs/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 集中式日志管理 VMware Aria …

C#测试调用FreeSpire.PDFViewer浏览PDF文件

Free Spire.PDFViewer是商业版Spire.PDFViewer的社区版本,支持以控件形式打开并查看PDf文件,但由于是免费版本,存在使用限制,打开的PDF文档只显示前10页内容。如果日常操作的pdf文件都不超过10页,可以考虑使用Free Spi…

Redis: Sorted Set 底层算法的简单分析

概述 我们先看下 Shorted Set 有序集合的内部数据结构所谓有序集合,比如有个容器,容器里边都已经排好序了,那无非就是快速的查找和插入不管你是查找还是插入,肯定要确定那个位置最简单的办法就是从最开头开始,挨个比较…

【unity进阶知识6】Resources的使用,如何封装一个Resources资源管理器

文章目录 一、Unity资源加载的几种方式1、Inspector窗口拖拽2、Resources3、AssetBundle4、Addressables(可寻址资源系统)5、AssetDatabase 二、准备三、同步加载Resources资源1、Resources.Load同步加载单个资源1.1、基本加载1.2、加载指定类型的资源1.…

无源码实现免登录功能

因项目要求需要对一个没有源代码的老旧系统实现免登录功能,系统采用前后端分离的方式部署,登录时前端调用后台的认证接口,认证接口返回token信息,然后将token以json的方式存储到cookie中,格式如下: 这里有…

HTTPS加密流程

本文尽量用最小的篇幅来介绍HTTPS的加密过程,如果还看不懂可以参考文末尾的文章。 加密算法 先简单介绍一下HTTPS中使用的是混合加密算法,即对称加密和非对称加密的混合使用: 1.对称加密:顾名思义就是加密和解密都是使用同一个密钥。 优点…

MySQL 问题小结

mysqld --initialize 初始化 data 文件夹 初始化的密码在这个 err 文件夹中

DC00025【含论文】基于协同过滤推荐算法springboot视频推荐管理系统

1、项目功能演示 DC00025【含文档】基于springboot短视频推荐管理系统协同过滤算法视频推荐系统javaweb开发程序设计vue 2、项目功能描述 短视频推荐系统分为用户和系统管理员两个角色 2.1 用户角色 1、用户登录、用户注册 2、视频中心:信息查看、视频收藏、点赞、…

数据链路层 ——MAC

目录 MAC帧协议 mac地址 以太网帧格式 ARP协议 ARP报文格式​编辑 RARP 其他的网络服务或者协议 DNS ICMP协议 ping traceroute NAT技术 代理服务器 网络层负责规划转发路线,而链路层负责在网络节点之间的转发,也就是"一跳"的具体传输…

Qt_绘图

目录 1、绘图核心类 2、QPainter类的使用 2.1 绘制线段 2.2 绘制矩形 2.3 绘制圆形 2.4 绘制文本 3、QPen类的使用 3.1 使用画笔 4、QBrush类的使用 4.1 使用画刷 5、绘制图片 5.1 测试QPixmap 5.1.1 图片移动 5.1.2 图标缩小 5.1.3 旋转图片 5.1.4 将…

【四】Spring Cloud OpenFeign原理分析

Spring Cloud OpenFeign原理分析 概述 Spring Cloud 微服务实践也有挺多年了,一直想着总结一下这系列的知识点,最近终于下定决心来出一个Spring Cloud 系列文章了。本文主要围绕fegin组件来进行讲解,文中将会给出基础使用的示例,还…

docker-compose 快速部署clickhouse集群

在本教程中,我们将学习如何使用 Docker Compose 部署一个带有三节点的 ClickHouse 集群,并使用 ZooKeeper 作为分布式协调服务。 前提条件 注意事项: 镜像版本号注意保持一致 [zookeeper:3.7, clickhouse/clickhouse-server:22.5.4]config…

uniapp微信小程序使用ucharts遮挡自定义tabbar的最佳解决方案

如图所示: 使用的ucharts遮挡住了我自定义的tabbar(如果不是提需求的有病,我才不会去自定义tabbar) 查阅了不少文档,说是开启 ucharts 的 canvas2d 即可: 官网文档地址: uCharts官网 - 秋云…

资源《Arduino 扩展板1-LED灯》说明。

资源链接:Arduino 扩展板1-LED灯 1.文件明细: 2.文件内容说明 包含:AD工程、原理图、PCB。 3.内容展示 4.简述 该文件为PCB工程,采用AD做的。 该文件打板后配合Arduino使用,属于Arduino的扩展板。 该文件主要有…

深度学习自编码器 - 分布式表示篇

序言 深度学习作为人工智能领域的重要分支,其核心在于表示学习( Representation Learning \text{Representation Learning} Representation Learning),尤其是分布式表示( Distributed Representation \text{Distribut…

netty之基础aio,bio,nio

前言 在Java中,提供了一些关于使用IO的API,可以供开发者来读写外部数据和文件,我们称这些API为Java IO。IO是Java中比较重要知识点,且比较难学习的知识点。并且随着Java的发展为提供更好的数据传输性能,目前有三种IO共…

Go基础学习06-Golang标准库container/list(双向链表)深入讲解;延迟初始化技术;Element;List;Ring

基础介绍 单向链表中的每个节点包含数据和指向下一个节点的指针。其特点是每个节点只知道下一个节点的位置,使得数据只能单向遍历。 示意图如下: 双向链表中的每个节点都包含指向前一个节点和后一个节点的指针。这使得在双向链表中可以从前向后或从后…

无人机之数据提取篇

一、无人机平台与传感器 无人机是进行数据采集的基础设施,其稳定性、可靠性、灵活性和负载能力直接影响到数据采集的效果。根据实际需求,需选择适合的无人机类型,如固定翼无人机适合大范围、长时间的数据采集,而多旋翼无人机则更适…

HTML基础用法介绍一

VS code 如何快速生成HTML骨架注释是什么?为什么要写注释?注释的标签是什么?标题标签段落标签换行标签与水平线标签 (都是单标签)文本格式化标签图片标签超链接标签音频标签视频标签 🚘正片开始 VS code 如何快速生成…