python设计模式之命令模式的组成、场景、特点、示例
off999 2024-10-27 11:57 27 浏览 0 评论
命令模式(Command Pattern)是一种常用的设计模式,属于行为型模式的一种。它的主要目的是将一个请求封装为一个对象,从而允许用户使用不同的请求、队列或者日志来参数化其他对象。命令模式也支持可撤销的操作。
1 命令模式的组成
命令模式通常包括以下几个角色:
- Command:命令接口,声明执行操作的接口。
- ConcreteCommand:具体命令,实现命令接口,并调用接收者的一个或多个动作来完成具体的命令。会保持一个接受者的引用。它是一个容器并不会执行具体处理
- Invoker:调用者,负责调用命令对象执行请求。
- Receiver:接收者,知道如何实施与执行一个请求相关的操作。
- Client:客户端,创建一个具体命令对象,并设置其接收者。
2 使用场景
命令模式在实际场景中的作用主要体现在以下几个方面:
- 解耦调用者和接收者:
命令模式可以将发出命令的对象和接收以及执行命令的对象解耦。这意味着命令的发送者不需要知道具体是谁执行的命令,也不需要知道命令是如何实现的。这种解耦使得系统更加灵活,易于扩展和修改。 - 命令的排队与执行:
命令模式允许将命令保存在队列中,然后在需要的时候依次执行。这在多线程程序中特别有用,可以在一个线程中排队命令,并在另一个线程中一一执行,有效地实现了线程间的任务调度。 - 支持撤销和重做操作:
命令模式可以通过实现撤销(undo)和重做(redo)命令来支持用户的撤销操作,这在编辑器、图形界面工具等需要提供用户操作回退功能的应用中非常有用。 - 支持操作的宏命令:
通过命令模式,可以将多个命令组合成一个宏命令,然后以单一命令的方式执行。这种方式常用于实现复杂的用户界面操作、事务性操作,或是需要一系列步骤共同完成一个任务的场景。 - 动态调整命令:
由于命令是对象,可以在运行时动态地改变命令的参数,或者完全更换执行的命令。这为动态调整程序的行为提供了极大的灵活性。 - 日志和事务:
命令模式可以用来记录详细的日志,记录用户的具体操作,或者在需要的时候,实现对命令的持久化。在软件崩溃后,这些记录可以用来恢复用户的操作。在事务型系统中,可以用命令模式来实现事务的提交和回滚。
3 特点
- 解耦命令的发出者和执行者:发出请求的对象与接收和执行请求的对象是解耦的。
- 扩展性好:可以很容易地新增命令或者改变命令的执行者。
- 组合命令:可以组合多个命令,实现复杂的功能。
- 支持撤销操作:命令模式可以用来实现命令的撤销和重做。-
4 示例代码
- 用户界面按钮和菜单项:GUI中的每个按钮或菜单项基本上都是一个命令模式的实现。
- 多级撤销功能:通过命令模式实现命令的历史记录,用户可以进行撤销或重做操作。
- 事务型行为:命令模式可以与数据库事务结合使用,用于实现事务的逻辑,其中每个操作都可以看作是一个命令。
- 排队请求:比如工作队列的设计,将请求排队,并在不同的时间点处理它们。
- 复合命令:可以组合多个命令,形成宏命令。
4.1 用户界面按钮和菜单项
一个简单的遥控器操作电灯的开关:
class Command:
def execute(self):
pass
class Light:
"""接收者:电灯,执行与电灯相关的操作"""
def turn_on(self):
print("电灯打开了。")
def turn_off(self):
print("电灯关闭了。")
class TurnOnCommand(Command):
"""具体命令:打开电灯"""
def __init__(self, light):
self.light = light
def execute(self):
self.light.turn_on()
class TurnOffCommand(Command):
"""具体命令:关闭电灯"""
def __init__(self, light):
self.light = light
def execute(self):
self.light.turn_off()
class RemoteControl:
"""调用者:遥控器,发出命令的请求"""
def __init__(self):
self.command = None
def set_command(self, command):
self.command = command
def press_button(self):
self.command.execute()
# 客户端代码
light = Light()
turn_on = TurnOnCommand(light)
turn_off = TurnOffCommand(light)
remote = RemoteControl()
remote.set_command(turn_on)
remote.press_button()
remote.set_command(turn_off)
remote.press_button()
一个文本编辑器的例子 使用命令模式来实现复制和粘贴功能:
class Command:
def execute(self):
pass
class TextEditor:
def __init__(self, text=''):
self.text = text
self.clipboard = ''
def copy(self):
self.clipboard = self.text
print(f"已复制: {self.clipboard}")
def paste(self):
self.text += self.clipboard
print(f"当前文本: {self.text}")
class CopyCommand(Command):
def __init__(self, editor):
self.editor = editor
def execute(self):
self.editor.copy()
class PasteCommand(Command):
def __init__(self, editor):
self.editor = editor
def execute(self):
self.editor.paste()
editor = TextEditor("Hello")
copy_cmd = CopyCommand(editor)
paste_cmd = PasteCommand(editor)
copy_cmd.execute()
paste_cmd.execute()
4.2 多级撤销功能
一个简单的计算器,能够执行操作并支持撤销功能:
class Command:
def execute(self):
pass
def undo(self):
pass
class Calculator:
def __init__(self):
self.value = 0
def add(self, num):
self.value += num
print(f"当前值: {self.value}")
def subtract(self, num):
self.value -= num
print(f"当前值: {self.value}")
class AddCommand(Command):
def __init__(self, calc, num):
self.calc = calc
self.num = num
def execute(self):
self.calc.add(self.num)
def undo(self):
self.calc.subtract(self.num)
calc = Calculator()
cmd = AddCommand(calc, 10)
cmd.execute()
cmd.undo()
4.3 事务型行为
模拟了数据库事务的基本操作:
class Command:
def execute(self):
pass
def rollback(self):
pass
class Database:
def __init__(self):
self.data = {}
def insert(self, key, value):
self.data[key] = value
print(f"插入: {key} -> {value}")
def delete(self, key):
if key in self.data:
del self.data[key]
print(f"删除: {key}")
class InsertCommand(Command):
def __init__(self, db, key, value):
self.db = db
self.key = key
self.value = value
def execute(self):
self.db.insert(self.key, self.value)
def rollback(self):
self.db.delete(self.key)
db = Database()
cmd = InsertCommand(db, 'id1', 'Data 1')
cmd.execute()
cmd.rollback()
4.4 排队请求
如何使用命令模式将请求排队并在不同的时间点处理:
from queue import Queue
class Command:
def execute(self):
pass
class Worker:
def do_something(self, msg):
print(f"工作内容: {msg}")
class DoSomethingCommand(Command):
def __init__(self, worker, msg):
self.worker = worker
self.msg = msg
def execute(self):
self.worker.do_something(self.msg)
queue = Queue()
worker = Worker()
queue.put(DoSomethingCommand(worker, "任务1"))
queue.put(DoSomethingCommand(worker, "任务2"))
while not queue.empty():
cmd = queue.get()
cmd.execute()
4.5 复合命令
通过命令模式实现的宏命令示例,可以执行一系列命令:
class Command:
def execute(self):
pass
class MacroCommand(Command):
def __init__(self):
self.commands = []
def add_command(self, cmd):
self.commands.append(cmd)
def execute(self):
for cmd in self.commands:
cmd.execute()
class SimpleCommand(Command):
def __init__(self, payload):
self.payload = payload
def execute(self):
print(f"执行: {self.payload}")
macro = MacroCommand()
macro.add_command(SimpleCommand("步骤1"))
macro.add_command(SimpleCommand("步骤2"))
macro.execute()
相关推荐
- 使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
命令行应用程序是开发人员最好的朋友。想快速完成某事?只需敲击几下键盘,您就已经拥有了想要的东西。Python是许多开发人员在需要快速组合某些东西时选择的第一语言。但是我们拼凑起来的东西在大多数时候并...
- Python 闭包:从底层逻辑到实战避坑,附安全防护指南
-
一、闭包到底是什么?你可以把闭包理解成一个"带记忆的函数"。它诞生时会悄悄记下自己周围的变量,哪怕跑到别的地方执行,这些"记忆"也不会丢失。就像有人出门时总会带上...
- 使用Python实现九九乘法表的打印_用python打印一个九九乘法表
-
任务要求九九乘法表的结构如下:1×1=11×2=22×2=41×3=32×3=63×3=9...1×9=92×9=18...9×9=81使用Python编写程序,按照上述格式打印出完整的九...
- 吊打面试官(四)--Java语法基础运算符一文全掌握
-
简介本文介绍了Java运算符相关知识,包含运算规则,运算符使用经验,特殊运算符注意事项等,全文5400字。熟悉了这些内容,在运算符这块就可以吊打面试官了。Java运算符的规则与特性1.贪心规则(Ma...
- Python三目运算基础与进阶_python三目运算符判断三个变量
-
#头条创作挑战赛#Python中你学会了三步运算,你将会省去很多无用的代码,我接下来由基础到进阶的方式讲解Python三目运算基础在Python中,三目运算符也称为条件表达式。它可以通过一行代码实现条...
- Python 中 必须掌握的 20 个核心函数——set()详解
-
set()是Python中用于创建集合的核心函数,集合是一种无序、不重复元素的容器,非常适合用于成员检测、去重和数学集合运算。一、set()的基本用法1.1创建空集合#创建空集合empty_se...
- 15个让Python编码效率翻倍的实用技巧
-
在软件开发领域,代码质量往往比代码数量更重要。本文整理的15个Python编码技巧,源自开发者在真实项目中验证过的工作方法,能够帮助您用更简洁的代码实现更清晰的逻辑。这些技巧覆盖基础语法优化到高级特性...
- 《Python从小白到入门》自学课程目录汇总(和猫妹学Python)
-
小朋友们好,大朋友们好!不知不觉,这套猫妹自学Python基础课程已经结束了,猫妹体会到了水滴石穿的力量。水一直向下滴,时间长了能把石头滴穿。只要坚持不懈,细微之力也能做出很难办的事。就比如咱们的学习...
- 8÷2(2+2) 等于1还是16?国外网友为这道小学数学题吵疯了……
-
近日,国外网友因为一道小学数学题在推特上争得热火朝天。事情的起因是一个推特网友@pjmdoll发布了一条推文,让他的关注者解答一道数学题:Viralmathequationshavebeen...
- Python学不会来打我(21)python表达式知识点汇总
-
在Python中,表达式是由变量、运算符、函数调用等组合而成的语句,用于产生值或执行特定操作。以下是对Python中常见表达式的详细讲解:1.1算术表达式涉及数学运算的表达式。例如:a=5b...
- Python运算符:数学助手,轻松拿咧
-
Python中的运算符就像是生活中的数学助手,帮助我们快速准确地完成这些计算。比如购物时计算总价、做家务时分配任务等。这篇文章就来详细聊聊Python中的各种运算符,并通过实际代码示例帮助你更好地理解...
- Python学不会来打我(17)逻辑运算符的使用方法与使用场景
-
在Python编程中,逻辑运算符(LogicalOperators)是用于组合多个条件表达式的关键工具。它们可以将多个布尔表达式连接起来,形成更复杂的判断逻辑,并返回一个布尔值(True或Fa...
- Python编程基础:运算符的优先级_python中的运算符优先级问题
-
多个运算符同时出现在一个表达式中时,先执行哪个,后执行哪个,这就涉及运算符的优先级。如数学表达式,有+、-、×、÷、()等,优先级顺序是()、×、÷、+、-,如5+(5-3)×4÷2,先计算(5-3)...
- Python运算符与表达式_python中运算符&的功能
-
一、运算符分类总览1.Python运算符全景图2.运算符优先级表表1.3.1Python运算符优先级(从高到低)优先级运算符描述结合性1**指数右→左2~+-位非/一元加减右→左3*//...
- Python操作Excel:从基础到高级的深度实践
-
Python凭借其丰富的库生态系统,已成为自动化处理Excel数据的强大工具。本文将深入探讨五个关键领域,通过实际代码示例展示如何利用Python进行高效的Excel操作,涵盖数据处理、格式控制、可视...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 使用 python-fire 快速构建 CLI_如何搭建python项目架构
- Python 闭包:从底层逻辑到实战避坑,附安全防护指南
- 使用Python实现九九乘法表的打印_用python打印一个九九乘法表
- 吊打面试官(四)--Java语法基础运算符一文全掌握
- Python三目运算基础与进阶_python三目运算符判断三个变量
- Python 中 必须掌握的 20 个核心函数——set()详解
- 15个让Python编码效率翻倍的实用技巧
- 《Python从小白到入门》自学课程目录汇总(和猫妹学Python)
- 8÷2(2+2) 等于1还是16?国外网友为这道小学数学题吵疯了……
- Python学不会来打我(21)python表达式知识点汇总
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)