Python连载38-协程、可迭代、迭代器、生产者消费者模型

Python连载38-协程、可迭代、迭代器、生产者消费者模型,第1张

概述一、生产者消费者模型 import multiprocessingfrom time import ctimedef consumer(input_q): print("Into consumer:",ctime()) while True: #处理项 item = input_q.get()

一、生产者消费者模型

import multiprocessingfrom time import ctimedef 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","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()

 

二、协程

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))#判断是否是一个迭代器


三、源码

d26_2_consumer_and_producer_model.py

d27_1_iterable_and_iterator_and_their_transform.py

https://github.com/ruigege66/Python_learning/blob/master/d26_2_consumer_and_producer_model.py

https://github.com/ruigege66/Python_learning/blob/master/d27_1_iterable_and_iterator_and_their_transform.py?

2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,个人公众号,仅用于学习交流,后台回复”礼包“,获取大数据学习资料

 

总结

以上是内存溢出为你收集整理的Python连载38-协程、可迭代、迭代器、生产者消费者模型全部内容,希望文章能够帮你解决Python连载38-协程、可迭代、迭代器、生产者消费者模型所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1191240.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存