生产者消费者模型_协程、可迭代、迭代器、生产者消费者模型!

一、生产者消费者模型

import multiprocessing
from time import ctime
def consumer(input_q):
    print("Into consumer:",ctime())
    while True:
        #处理项
        item = input_q.get()
        print("pull",item,"out of q")#此处替换为有用的工作
        input_q.task_done()#发出信号通知任务完成
    print("Out of consumer:",ctime()) #此句未执行,因为q.join()收集到四个task_done()信号后,主进程启动
def producer(sequence,output_q):
    print("Into producer:",ctime())
    for item in sequence:
        output_q.put(item)
        print("put",item,"into_q")
    print("Out of producer:",ctime())
#建立进程
if __name__ == "__main__":
    q=multiprocessing.JoinableQueue()
    #运行消费者进程
    cons_p = multiprocessing.Process(target=consumer,args=(q,))
    cons_p.daemon = True
    cons_p.start()
​
    #生产多个项,sequence代表要发送给消费者的项序列
    #在实践中,这可能是生成器的输出或通过一些其他方式生产出来的
    sequence = [1,2,3,4]
    producer(sequence,q)
    #等待所有项被处理
    q.join()

Python资源共享群:626017123

e8af317a32919707b6cc33926717144c.png

二、协程

1.协程参考资料:

http://python.jobble.com/86481/

http://python.jobble.com/87310/

https://segmentfault.com/a/1190000009781688

2.迭代器参考资料

可迭代(iterable):直接作用于for循环变量

迭代器(Iterator):不但可以作用于for循环,还可以被next调用

3.关系:list是一个典型的可迭代对象,但是不是一个迭代器,因为list不可以被next调用

4.判断标准:通过isinstance来判断某个变量是否是一个实例,判断是否可以迭代

from collections import Iterable,Iterator
​
l = [i for i in range(5)]  #可迭代
print(isinstance(l,Iterable))#判断是否可迭代
print(isinstance(l,Iterator))#判断是否是一个迭代器
​
s_iter = iter(l)#将其转换为可以迭代的和迭代器
print(isinstance(s_iter,Iterable))#判断是否可迭代
print(isinstance(s_iter,Iterator))#判断是否是一个迭代器

02d465fa760fea2189c4d44b9171c38b.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值