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.xdnf.cn/news/1549323.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

CentOS8.5.2111(3)实验之DHCP服务器架设

一、实验目标 1.掌握DHCP服务器的主配置文件各项申明参数及操作及其含义 2. 具备DHCP 服务器、中继服务器的配置能力 3. 具备测试客户端正常获取服务器分配地址的能力 4. 具备DHCP服务器故障排除能力 二、实训原理/流程 (一)项目背景 …

python爬虫案例——抓取链家租房信息(8)

文章目录 1、任务目标2、分析网页3、编写代码1、任务目标 目标站点:链家租房版块(https://bj.lianjia.com/zufang/) 要求:抓取该链接下前5页所有的租房信息,包括:标题、详情信息、详情链接、价格 如: 2、分析网页 用浏览器打开链接,按F12或右键检查,进入开发者模式;因…

首屏优化之:SSR(服务端渲染)

引言 今天我们来聊一下首屏优化之SSR-服务端渲染(Server-Side Rendering)。 可能很多朋友并不了解什么是 SSR,包括在工作中写的网站是什么类型的也不太清楚,是 CSR 还是 SSR?作者在阅读过大量的文章之后,…

一文上手SpringSecurity【二】

书接上回,我们直接引入了spring security的依赖,之后啥也没有干,在访问接口的时候, 就需要认证之后才能访问了 ,咱们没有主动干啥,那肯定有人帮助我们干啥了,这一切都利益出spring boot自动装配机制,下面咱们就看看spring security的自动装配,帮助我们干啥了. 一、Spring Secur…

如何查看上网记录及上网时间?5种按步操作的方法分享!【小白也能学会!】

“知己知彼,百战不殆”,在数字时代,了解自己的上网行为和时长,不仅能帮助我们更好地管理时间,还能提升工作效率和生活质量。 今天,我们就来分享五种简单易懂的方法,即便是网络小白也能轻松学会…

某系统超级管理员密码重置通用型

故事的起因是意外发现某站点系统存在接口泄露,并且此接口可直接实现超级管理员密码重置,查ico找到用这个系统的站点,发现均存在此漏洞 首先打开系统站点,F12或者鼠标右键检查,然后刷新页面,在网络这里找到…

ECCV`24 | 高保真目标修复新SOTA!复旦智象开源CAT-Diffusion,语义视觉双一致

文章链接:https://arxiv.org/pdf/2409.08260 Github链接:https://github.com/Nnn-s/CATdiffusion 总结速览 解决的问题: 单一U-Net在所有去噪步骤中对齐文本提示和视觉对象不足以生成期望的对象。 扩散模型的复杂采样空间中无法保证对对象生成的可控性…

物流货运托运发货单二联三联打印软件定制 佳易王物流单管理系统操作教程

一、前言 物流货运托运发货单二联三联打印软件定制 佳易王物流单管理系统操作教程 1、软件为绿色免安装版,解压即可使用,已经内置数据库,不需再安装。 2、软件下载可以到本文章最后点击官网卡片下。 二、软件程序教程 1、如图,…

Html 转为 MarkDown

在 RAG 中,通常需要将 HTML 转为 Markdown,有很多第三方 API 都支持 HTML 的转换,本文使用一个代码文档的例子 https://www.joinquant.com/help/api/help#name:Stock,将聚宽 API 转为 Markdown。本文通过两种方式进行实现,使用收费和开源的解决方案。聚宽 API 格式转为 Ma…

crypto-js解密报错malformed utf-8 data

在进行加解密处理时出现这个问题。 但是当在一个完整程序运行环境内加密字符串,解密字符串是没问题的。 当把加密的字符存储到txt文件,在读取解密时出现错误无法解密。 最后,使用res.replace(/\s/g,‘’)正则过滤掉txt文件内的空格就成功了。…

爆火!大模型算法岗 100 道面试题全解析,赶紧收藏!

大模型应该是目前当之无愧的最有影响力的AI技术,它正在革新各个行业,包括自然语言处理、机器翻译、内容创作和客户服务等等,正在成为未来商业环境的重要组成部分。 截至目前大模型已经超过200个,在大模型纵横的时代,不…

【Kubernetes】常见面试题汇总(四十四)

目录 100.什么是容器资源监视? 101.副本集和复制控制器之间有什么区别? 特别说明: 题目 1-68 属于【Kubernetes】的常规概念题,即 “ 汇总(一)~(二十二)” 。 题目 69-113 …

mov视频怎么转换成mp4?这几种转换方法值得收藏起来!

mov视频怎么转换成mp4?MOV格式,作为苹果专属的产物,它在非苹果体系下的兼容性常常受限,导致用户可能在非苹果软件平台上遭遇播放难题,甚至无法顺利加载视频内容,而且,MOV格式以其独特的压缩技术…

干货 | 2024制造业数字化现状调查白皮书(免费下载)

导读:在这本白皮书中,我们询问了制造商有关数字化转型的工作情况、2024 年的优先事项和可持续性。研究结果清楚地表明,在数字化方面处于领先地位的制造商转型项目比那些没有规划或刚刚起步的项目实现的价值要大得多。 加入知识星球或关注下方…

青动CRM-E售后V2.0.4

CRM售后管理系统,旨在助力企业销售售后全流程精细化、数字化管理,主要功能:客户、合同、工单、任务、报价、产品、库存、出纳、收费,适用于:服装鞋帽、化妆品、机械机电、家具装潢、建材行业、快销品、母婴用品、办公用…

只需要两步制作GIF动态图,方便快捷,制作动态表情包的利器!

推荐阅读:Python制作进度条,18种方式全网最全!(不全去你家扫厕所!) 在日常生活中肯定会接触到gif,例如在写文章的时候,有时需要将自己的代码的运行结果展示出来,如果放一…

05-成神之路_ambari_Ambari实战-013-代码生命周期-metainfo-configFiles详解

1.Redis 集群 metainfo.xml 示例 <?xml version"1.0"?> <metainfo><schemaVersion>2.0</schemaVersion><services><service><!-- Redis 集群服务的基本信息 --><name>REDIS</name><displayName>Redi…

VulnHub-SickOs1.1靶机笔记

SickOs1.1靶机笔记 概述 Vulnhub的靶机sickos1.1 主要练习从互联网上搜取信息的能力&#xff0c;还考察了对代理使用&#xff0c;目录爆破的能力&#xff0c;很不错的靶机 靶机地址&#xff1a; 链接: https://pan.baidu.com/s/1JOTvKbfT-IpcgypcxaCEyQ?pwdytad 提取码: yt…

Kali Linux上安装远程桌面服务VNC

在Kali Linux上安装远程桌面服务VNC&#xff0c;可以按照以下步骤进行&#xff1a; 一、安装VNC Server 更新软件包列表&#xff1a; 在终端中运行以下命令&#xff0c;以确保你的软件包列表是最新的。 sudo apt update在执行更新之前会先验证当前账号密码&#xff0c;输入密码…

一种路径敏感的数据依赖分析算法

Falcon 1.方法1.1.Basic Rule1.2.改进算法1.3.跨函数分析 2.Evaluation2.1.设置2.2.value-flow分析2.3.Thin Slicing2.4.Bug Detection 参考文献 这篇工作发表于PLDI 24&#xff0c;提出了一种context- 以semi-path-sensitive的数据依赖分析算法&#xff0c;解决path-sensitive…