python之生产者与消费者模型

在并发编程中,如果生产者处理速度很快,消费者处理速度较慢,那生产者就必须等消费者处理完,反之亦然。

生产者消费者模式

生产者和消费者之间不进行直接通讯,而是通过阻塞队列来进行通讯。所以,阻塞队列就像是一个中间人,一个缓冲区,平衡了生产着和消费者的处理能力。

import queue
import threading
q =queue.Queue(10)
def producer(name):
    count =1
    while True:
        q.join()
        q.put(count)
        print("生产者{}正在生产{}个包子".format(name, count))
        count += 1


def countomer(name):
    count =1
    while True:
        baozi = q.get()
        print("消费者{}正在吃第{}哥个包子".format(name,baozi))
        count +=1
        q.task_done()
def main():
    t1 = threading.Thread(target=producer,args=("张三",))
    t2 = threading.Thread(target=countomer, args=("李四",))
    t1.start()
    t2.start()
if __name__ == '__main__':
    main()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值