Python之两种模式的生产者消费者模型详解
作者:haeasringnar 发布时间:2021-07-31 17:44:02
标签:Python,生产者,消费者
第一种使用queue队列实现:
#生产者消费者模型 其实服务器集群就是这个模型
# 这里介绍的是非yield方法实现过程
import threading,time
import queue
q = queue.Queue(maxsize=10)
def Producer(anme):
# for i in range(10):
# q.put('骨头%s'%i)
count = 1
while True:
q.put('骨头%s'%count)
print('生产了骨头',count)
count += 1
time.sleep(1)
def Consumer(name):
# while q.qsize() >0:
while True:
print('[%s] 取到[%s] 并且吃了它...'%(name,q.get()))
time.sleep(1)
p = threading.Thread(target=Producer,args=('shenchanzhe',))
c = threading.Thread(target=Consumer,args=('xiaofeizhe01',))
c1 = threading.Thread(target=Consumer,args=('xiaofeizhe02',))
p.start()
c.start()
c1.start()
使用yield协程的方法来实现生产者和消费者:
#生产者和消费者,使用生成器的方式,就是一个简单的并行,
import time
# 这是一个消费者 一直在等待完成吃包子的动作
def consumer(name):
print('%s准备吃包子了!'%name) #打印出对应的消费者的名字
while True: #执行一个死循环 实际上就是需要调用时才会执行,没有调用就会停止在yield
baozi = yield #在它就收到内容的时候后就把内容传给baozi
print('包子【%s】来了,被【%s】吃了'%(baozi,name))
def producer(name):
c1 = consumer('A') #它只是把c1变成一个生成器
c2 = consumer('B')
c1.__next__() #第一个next只是会走到yield然后停止
c2.__next__()
print('老子开始做包子了')
for i in range(1,10):
time.sleep(1)
print('三秒做了两个包子')
c1.send(i) #这一步其实就是调用next方法的同时传一个参数i给field接收,然后baozi=i
c2.send(i+1)
#其实这里是这样的,在send的时候只是继续执行yield下面的语句,然后去去yield,再次停在这儿
# producer('aea')
c = consumer('aaa') #没next一次就会将程序执行一次
c.__next__()
c.__next__()
c.__next__()
来源:https://blog.csdn.net/haeasringnar/article/details/79917253


猜你喜欢
- 在项目开发过程中,遇到如下用户体验提升需求:需要实现错误提示时根据后台返回错误列表信息,换行展示。实现方式如下:通过F12元素查看,在对应的
- 这个就没什么好说的了。。直接上代码啊!! 首先是HTML的代码。其中包含了登录点击按钮以及一个简陋的登录框。 <body> &l
- 关于采集-防采集的我想大家都很清楚。这个就不多说,采集最终还是从页面源代码入手,所以只要没有规律想采集就难!由于一天自己在策划某个网站的时候
- python这样注释,让你的代码看起来更加的优雅,是不是常常感觉自己的python代码写出来,看起来特别的乱,虽然可以正常运行,但是在优雅性
- 均匀性度量图像分割是图像像素分割的一种方法,当然还有其他很多的方法。这里简单的介绍下其原理和实现代码【有源码】其流程大概分为一下几步1、确定
- 本文实例为大家分享了Python使用Pygame绘制时钟的具体代码,供大家参考,具体内容如下前提条件:需要安装pygame功能:1.初始化界
- python对PPT演示文档读写,是通过第三方库python-pptx实现的,python-pptx是用于创建和更新 PowerPoint(
- 创建df:>>> df = pd.DataFrame(np.arange(16).reshape(4, 4), colum
- 在开发数据库应用或者调试代码时,经常需要获取系统的当前日期和时间,我们来看一下 PostgreSQL 中提供的相关函数。当前日期CURREN
- 日常项目中,读取各种配置文件是避免不了的,这里介绍一个能读取多种配置文件的库,viperviper读取ini文件config := vipe
- 我们来编写一个,引用时用:<!--#include Virtual="page.inc"-->语句即可:pa
- 问题你想使用一个装饰器去包装函数,但是希望返回一个可调用的实例。 你需要让你的装饰器可以同时工作在类定义的内部和外部。解决方案为了将装饰器定
- Python 中的函数eval()?是一个非常有用的工具,在前期,我们一起学习过该函数点击查看:Python eval 函数动态地计算数学表
- 你搜索这个,你会发现好多都是np.zeros(5,2),嗯都是复制的一个国外的帖子,然而没有翻译人家的话。然后你愤怒的关闭页面。这简直就是文
- 1.安装1.1 创建虚拟环境mkdir myprojectcd myprojectpython3 -m venv venv1.2 进入虚拟环
- 微信小程序开发内测一个月.数据传递的方式很少.经常遇到页面销毁后回传参数的问题,小程序中并没有类似Android的startActivity
- 页签的流行自从Yahoo!的首页引进页签(tab, 见下图)之后,这种可用性极佳的方式越来越受欢迎,用户也逐步习惯和喜欢上它,因为它可以在原
- 用python爬取网页表格数据,供大家参考,具体内容如下from bs4 import BeautifulSoup import reque
- 本文实例为大家分享了python定时复制远程文件夹中文件的具体代码,供大家参考,具体内容如下import os, shutil, sysim
- 一、条件变量与互斥锁条件变量是基于互斥锁的,它必须基于互斥锁才能发挥作用;条件变量并不是用来保护临界区和共享资源的,它是用来协调想要访问共享