Python中Queue的实现原理

生产者消费者模式

生产者消费者模式并不是GOF提出的众多模式之一,但它依然是开发同学编程过程中最常用的一种模式。

在这里插入图片描述

生产者模块负责产生数据,放入缓冲区,这些数据由另一个消费者模块儿来从缓冲区取出并进行消费者相应的处理。该模式的优点在于:

  • 解耦:缓冲区的存在可以让生产者和消费者降低互相之间的依赖性,一个模块儿代码变化,不会直接影响另一个模块儿
  • 并发:由于缓冲区,生产者和消费者不是直接调用,而是两个独立的并发主体,生产者产生数据之后把它放入缓冲区,就继续生产数据,不依赖消费者的处理速度

简单队列

消费者按FIFO取数据,一律平等。

class Queue:
    """
    队列 fifo
    """

    def __init__(self):
        self.__lst = []

    def push(self, uid: int) -> None:
        self.__lst.append(uid)

    def pop(self) -> int:
        return self.__lst.pop(0)

    def is_empty(self) -> bool:
        return not bool(self.__lst)

加权队列

消费者按FIFO取数据,当权重高的优先。

class WeightQueue:
    """
    加权队列
    """

    def __init__(self):
        self.__lst = []

    def push(self, uid: tuple) -> None:
        self.__lst.append(uid)

    def pop(self) -> tuple:
        self.__lst = sorted(self.__lst, key=lambda k: k[0], reverse=True)
        return self.__lst.pop(0)

    def is_empty(self) -> bool:
        return not bool(self.__lst)

小结:

python中有很多数据结构,而解决消费者的处理速度的问题就是队列,还有很多队列例如,双端队列等等,可以更好的解决实际问题。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

楼下安同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值