Python:设计模式之命令模式

简介: Python:设计模式之命令模式

命令模式

命令模式属于行为型模式

行为型模式侧重于对象的响应性,利用对象之间的交互实现更强大的功能

其中对象用于封装在完成一项操作或在触发一个事件时所需的全部信息:

1、方法名称

2、拥有方法的对象

3、方法参数的值


命令模式术语

Command: 声明执行操作的接口

ConcreteCommand:将一个Receiver对象和一个操作绑定在一起

Receiver:创建ConcreteCommand对象并设定其接收者

Invoker:要求该ConcreteCommand执行这个请求

Client:知道如何实施与执行一个请求相关的操作


执行流程:

客户端请求执行命令,

调用者接受命令,封装它并将其放置到队列中,

ConcreteCommand类根据所请求的命令来知道接收者执行特定的动作


命令模式主要意图

1、将请求封装为对象

2、可用不同的请求对客户进行参数化

3、允许将请求保存在队列中

4、提供面向对象的回调


命令模式适用场景

1、根据需要执行的操作对对象进行参数化

2、将操作添加到队列并在不同地点执行请求

3、创建一个结构来根据较小操作完成高级操作


命令模式应用

1、重做或回滚操作

2、异步任务执行


命令模式的优点

1、将调用操作的类与知道如何执行该操作的对象解耦

2、提供队列系统后,可以创建一系列命令

3、添加新命令更容易,并且无需更改现有代码

4、可以使用命令模式定义回滚系统


命令模式的缺点

1、为了实现目标,需要大量的类和对象进行协作

2、每个单独的命令都是一个ConcreteCommand类,从而增加了需要实现和维护的类的数量


代码实例:

# -*- coding: utf-8 -*-

from abc import ABCMeta, abstractmethod


# 提供接口Command
class Order(metaclass=ABCMeta):
    @abstractmethod
    def execute(self):
        pass


# 具体命令 ConcreteCommand
class BuyStockOrder(Order):
    def __init__(self, stock):
        self.stock = stock

    def execute(self):
        self.stock.buy()


class SellStockOrder(Order):
    def __init__(self, stock):
        self.stock = stock

    def execute(self):
        self.stock.sell()


# Receiver对象
class StockTrade(object):
    def buy(self):
        print("buy stock")

    def sell(self):
        print("sell stock")


# 调用者Agent,中介
class Broker(object):
    def __init__(self):
        self.__order_list = []  # 订单队列

    def add_order(self, order):
        self.__order_list.append(order)

    def place_order(self):
        for order in self.__order_list:
            order.execute()

        self.__order_list.clear()


if __name__ == '__main__':
    # client
    stock = StockTrade()
    buy_stock = BuyStockOrder(stock)
    sell_stock = SellStockOrder(stock)

    # invoker
    broker = Broker()
    broker.add_order(buy_stock)
    broker.add_order(sell_stock)

    broker.place_order()
"""
buy stock
sell stock
"""

参考

Python设计模式第2版》第七章 命令模式-封装调用

            </div>
目录
相关文章
|
Java Maven
关于 Could not find artifact ...:pom:1.0-SNAPSHOT 的问题!
关于 Could not find artifact ...:pom:1.0-SNAPSHOT 的问题!
3119 0
关于 Could not find artifact ...:pom:1.0-SNAPSHOT 的问题!
|
安全 大数据 Java
elasticsearch|大数据|低版本的elasticsearch集群的官方安全插件x-pack的详解
elasticsearch|大数据|低版本的elasticsearch集群的官方安全插件x-pack的详解
325 0
|
10月前
|
编解码 异构计算
YOLOv11改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
YOLOv11改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
2727 7
YOLOv11改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
|
安全 Linux 网络安全
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
130573 0
|
SpringCloudAlibaba Cloud Native Java
license版权证书生成与验证
License,即版权许可证,一般用于收费软件给付费用户提供的访问许可证明。根据应用部署位置的不同,一般可以分为以下两种情况讨论: - 应用部署在开发者自己的云服务器上,如现在的saas模式的软件供应商就是这样部署的。这种情况下用户通过账号登录的形式远程访问,因此只需要在账号登录的时候校验目标账号的有效期、访问权限等信息即可。 - 应用部署在客户的内网环境,即本地化部署。因为这种情况开发者无法控制客户的网络环境,也不能保证应用所在服务器可以访问外网,因此通常的做法是使用服务器许可文件,在应用启动的时候加载
3814 0
license版权证书生成与验证
CentOS8配置Postfix开启SASL找不到服务
CentOS8配置Postfix开启SASL找不到服务
CentOS8配置Postfix开启SASL找不到服务
|
移动开发 监控 前端开发
人脸识别会议系统性能优化
1.不要盯着问题看。对于app的性能优化也好,系统优化也好。问题的表象可能是由于本质的副作用带来的。2. 用数据说话。不要凭感觉,去检测性能问题、评估性能优化的效果,要有可量化的渲染性能评判标准,以及可量化、可视化的优化工具。利用经验去感觉、猜测对于团队是没有沉淀的,而数据和工具是可以传承的。3.使用低配置的设备:同样的程序,在低端配置的设备中,相同的问题会暴露得更为明显。4.权衡利弊:在能够保证产品稳定、按时完成需求的前提下去做优化,投入产出比过高时,应采取其他方案,切勿过度优化。永远不要忘记,优化性能的目的是提高用户体验,而不是炫技。5.抛弃沉没成本......
人脸识别会议系统性能优化
|
新零售 物联网 大数据
关于ORA-12801,ORA-27090的简单分析
今天下午收到客户的邮件,说有一个job在运行的时候报错了,希望我们能帮忙看看是什么原因。 ERROR: Caught en exception: ORA-12801: error signaled in parallel query server P130 O...
1661 0