繁体   English   中英

Python的queue.Queue get / put方法在阻塞时是否持有该队列的锁?

[英]Do Python's queue.Queue get/put methods hold the lock for that queue while blocking?

我有一个传统的多线程生产者/消费者模式, 中间有一个queue.Queue 队列的这种实现是线程安全的。 使用者可以通过两种方式使用数据:

闭塞

while self.running:
    data = self.receiver_q.get(block=True)
    # do something with data

非阻塞

while self.running:
    try:
        data = self.receiver_q.get(block=False)
    except queue.Empty:
        continue
    # do something with data

在阻塞方法中,使用者等待直到队列中有数据为止。 在这段时间中,消费者是否将锁定锁定在队列中? 我无法想象一种在允许队列中放置新数据的同时保持锁的方法。

此外,两种模式之间是否存在性能差异?

(1)不,消费者未持有锁; 它只是被阻塞,直到满足请求为止,但是队列仍然可用。 如果有多个消费者,则该消费者位于潜在的收件人池中。 解析功能将选择满意度的顺序。

(2)任何性能差异都取决于实现方式。 不要问我们-您拥有最重要的权限:您的计算机。 使用您选择的测试方案和timeit工具。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM