Python的多线程有个队列模块Queue
这个模块就相当于创建一个线程池。举一个例子说明。一下这个Queue,比如我每天都去的吃的乔晨粗粮包子店。假如这个包子店的锅炉一次只能蒸100个包子,那就意味着面点师傅只要做满了100个就没办法做了,等着消费者来将里面消费到一定程度之后重新开始做。
运用到Python就是这个Queue就是那个锅炉,容器。将线程生产出来的数据放到这个容器当中,通过queue.put()将数据放到容器中。,先进先出,然后消费者从这个容器中拿数据,queue.get()获取数据
队列实现生产者消费者模型。
这个模型大概就是有生产者生产包子,生产的包子放到Quque当中,消费者再从Queue当中取包子。
import threading
import time
# 生产者函数
def producers(name, que):
while True:
if q.qsize < 10
# put方法用于往队列放数据
que.put('包子')
print u'%s:生产了一个包子' % name
time.sleep(random.randrange(5))
def consumers(name, que):
while True:
try:
#get 方法取出数据, get_nowait 如果队列中没有数据则就报错
que.get_nowait('包子')
print u'%s: 消费了一个包子' %s name
except Exception:
print u'没有包子了'
time.sleep(random.randrange(3))
q = Que.Que()
# 使用两个线程生产
p1 = threading.Thread(target=producers, args=(u'厨师1', q))
p2 = thread.Thread(target=producers, args=(u'厨师2', q))
p1.start()
p2.start()
# 两个线程是消费者
c1 = thread.Thread(target=consumers, args=(u'消费者1', q))
c1 = thread.Thread(target=consumers, args=(u'消费者2', q))
c1.start()
c1.start()