生产者和消费者模型producer and consumer(单线程下实现高并发)

生产者和消费者模型producer and consumer(单线程下实现高并发)

#1、生产者和消费者模型producer and consumer model
import time
def producer():
ret = []
for i in range(2):
time.sleep(0.2)
ret.append("包子%s" %i)
return ret
def consumer(res):
for index,baozi in enumerate(res):
time.sleep(0.2)
print("第%s个人,吃了%s" %(index,baozi))
res = producer()
consumer(res)
print("上面的结束了-------------------------------------------------------------")
#2、单线程下实现高并发
def test():
print("开始啦")
firt = yield #这个1相当于return的1,相当于函数的返回值,而yield会接收一个值传送给firt,这个firt是函数内部的局部变量
print("第一次",firt)
yield 2
print("第二次")
t = test()
res = t.__next__() #等同于next(t) 定义res的意思是定义返回值也就是上面的yield的返回值1
print(res)
# t.__next__()
#生成器下面的send方法
# res = t.send(None) #t.send(None)就send给yield1了 yield1可以赋值firt send(None)可以保证函数接着运行 send(None)里面的参数会传给赋值
res = t.send("函数停留在first那个位置,我就是给first赋值的") #send可以触发
print(res)
#t.__next__方法就等同于t.send(None)方法
print("上面的结束了了了--------------------------------------------------------------------------------------------------------ll")
#并发:两个程序同时在等待,A程序生产完成调到B程序,B程序生产完成以后再跳到A程序,来回切换的过程,两个程序没有先后的顺序
import time
def consumer(name):
print("我是[%s,我准备开始吃包子了]" %name)
while True:
baozi = yield #yield代表等待包子的过程
time.sleep(1)
print("%s 很开心的把【%s】吃掉了" %(name,baozi))
def producer():
c1 = consumer("wupeiqi")
c2 = consumer("yuanhao_SB")
c1.__next__()
c2.__next__()
for i in range(10):
time.sleep(1)
c1.send("包子 %s" %i)
c2.send("包子 %s" %i)
producer() #调用producer函数由send触发了另外一个函数,由另外一个函数结束了以后又跳到了原先的函数,然后接着send
上一篇:JavaScript中return的用法和this的用法详解


下一篇:MySQL中tinytext、text、mediumtext和longtext详解