python之函数实现生产者消费者模型(开发模型)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python之函数实现生产者消费者模型(开发模型)相关的知识,希望对你有一定的参考价值。

#!/usr/bin/env /python

import threading
import time
import Queue
import random

#生产者
def Proudcer(name,que):
    while True:
        if que.qsize() < 3: #如果只剩下3个包子就又开始生产包子(如果队列中的数据为3个时)
            que.put(‘baozi‘) #包子入队列
            print ‘%s 生产包子...‘ % name
        else:
            print "%s 仅剩3个包子..."
        time.sleep(random.randrange(5)) #随机在1-5秒内开始生产包子(推迟调用线程的运行,可通过参数secs指秒数,表示进程挂起的时间)

#消费者
def Consumer(name,que):
    while True:
        try:
            que.get_nowait() #消费者消费包子(从队列取数据,且为非阻塞模式,如果队列为空了,则会引发出异常)
            print ‘ %s 消费包子...‘ % name
            time.sleep(random.randrange(3))  #随机在1-3秒内开始消费包子(推迟调用线程的运行,可通过参数secs指秒数,表示进程挂起的时间)
        except Exception:
            print u‘包子已卖完...‘ #捕捉队列为空时引发的异常


#定义一个队列存用来储包子
q = Queue.Queue()

#创建第1个厨师 (也就是线程1,传入name参数:“tantianran”和队列q)
p1 = threading.Thread(target=Proudcer,args=[‘tantianran‘,q])
#创建第2个厨师 (也就是线程2
p2 = threading.Thread(target=Proudcer,args=[‘dengwenqing‘,q])
#启动线程(线程是同时工作)
p1.start()
p2.start()

#创建2个消费者线程分别为c1和c2
c1 = threading.Thread(target=Consumer,args=[‘xiaofeizhe1‘,q])
c2 = threading.Thread(target=Consumer,args=[‘tanyongxing‘,q])
#启动线程(线程是同时工作)
c1.start()
c2.start()


本文出自 “运维交流Q群:223843163” 博客,请务必保留此出处http://freshair.blog.51cto.com/8272891/1898467

以上是关于python之函数实现生产者消费者模型(开发模型)的主要内容,如果未能解决你的问题,请参考以下文章

并发编程之多进程3 (生产者与消费者模型) 回调函数

11.python并发入门(part8 基于线程队列实现生产者消费者模型)

python学习_day35_并发编程之多进程3

python队列生产者消费者模型

线程同步之经典模型 —— 生产者消费者模型

线程同步之经典模型 —— 生产者消费者模型