美文网首页
生产者-消费者问题与python Queue模块

生产者-消费者问题与python Queue模块

作者: mudssky | 来源:发表于2019-06-08 14:31 被阅读0次

生产者-消费者问题与python Queue模块
生产者-消费者模型是一个典型的场景,在这个场景下,商品或服务的生产者生产商品,然后将其放到类似队列的数据结构中。生产商品的时间是不确定的,同样消费者消费生产者的商品的时间也是不确定的。
下面我们用Queue模块编写一个演示程序,帮助理解。
典型的应用比如说下载软件多线程下载的时候,可以通过队列来分配任务,设置任务的优先顺序等。但是这里就先借用书上的例子了。

import random
import time
from queue import Queue
import threading


def writeQ(queue):
    print('producing object for Q...')
#     put(item,block=True,timeout=None)
#    默认block为True,block为True,timeout=None就表示,在遇到可用空间之前会阻塞
    queue.put('xxx',1)
#     queue.qsize() 获取当前队列大小,由于返回时队列大小可能被其他线程修改,所以该值为近似值
    print("producer ,size now",queue.qsize())

def readQ(queue):
    val = queue.get(1)
    print('consumed object from Q... size now',queue.qsize())

def writer(queue,loops):
    for i in range(loops):
        writeQ(queue)
        time.sleep(random.randint(1,3))
def reader(queue,loops):
    for i in range(loops):
        readQ(queue)
        time.sleep(random.randint(2,5))

funcs = [writer,reader]
# 书上很多骚操作,这一步实际上生成了[0,1]
nfuncs=range(len(funcs))

def main():
    nloops = random.randint(2,5)
    q=Queue(32)
    threads=[]
    for i in nfuncs:
        t=threading.Thread(target=funcs[i],args=(q,nloops))
        threads.append(t)
    
    for t in threads:
        t.start()
        
    for t in  threads:
        t.join()
    print('all DONE')

if __name__=='__main__':
    main()

producing object for Q...
producer ,size now 1
consumed object from Q... size now 0
producing object for Q...
producer ,size now 1
producing object for Q...
producer ,size now 2
consumed object from Q... size now 1
producing object for Q...
producer ,size now 2
consumed object from Q... size now 1
producing object for Q...
producer ,size now 2
consumed object from Q... size now 1
consumed object from Q... size now 0
all DONE

编写这种并发的程序还是go语言方便啊,队列和多线程类似的东西都是语言内置语法,简单,代码量很少。性能也会高得多

相关文章

  • 生产者-消费者问题与python Queue模块

    生产者-消费者问题与python Queue模块生产者-消费者模型是一个典型的场景,在这个场景下,商品或服务的生产...

  • PYTHON多线程行情抓取工具实现

    思路 借助python当中threading模块与Queue模块组合可以方便的实现基于生产者-消费者模型的多线程模...

  • Python: Queue实现生产者及消费者模型

    Python Queue模块是一个线程安全的队列。基于Queue实现生产者及消费者模型如下。参考Effective...

  • 说说Python中的queue

    背景 最近在看Python基础,刚好看到生产者与消费者这快内容,视频使用了queue模块来处理,这里记录一下学习的...

  • 2018-07-27

    17.7.queue- 同步队列类源代码:Lib / queue.py 该queue模块实现了多生产者,多消费者队...

  • ActiveMQ(三)整合spring

    配置 生产者 topic 生产者 queue 接受应答 消费者Queue应答 消费者topic

  • ActiveMQ(二)原生API

    Maven配置 生产者 消费者 queue 消费者 topic

  • python queue

    Queue queue 模块实现多生产者,多消费者队列。当信息必须安全的在多线程之间交换时,它在线程编程中是特别有...

  • Queue的一些笔记

    queue模块实现了多生产者,多消费者的队列。当 要求信息必须在多线程间安全交换,这个模块在 线程编程时非常有用 ...

  • 2020-08-11 queue 笔记

    queue 一个同步的队列 queue模块实现了多生产者、多消费者队列。这特别适用于消息必须安全地在多线程间交换的...

网友评论

      本文标题:生产者-消费者问题与python Queue模块

      本文链接:https://www.haomeiwen.com/subject/lzsixctx.html