浅析python协程相关概念


Posted in Python onJanuary 20, 2018

这篇文章是读者朋友的python协程的学习经验之谈,以下是全部内容:

协程的历史说来话长,要从生成器开始讲起。

如果你看过我之前的文章python奇遇记:迭代器和生成器 ,对生成器的概念应该很了解。生成器节省内存,用的时候才生成结果。

 

# 生成器表达式
a = (x*x for x in range(10))
# next生成值
next(a()) # 输出0
next(a()) # 输出1
next(a()) # 输出4

与生成器产出数据不同的是,协程在产出数据的同时还可以接收数据,具体来说就是把yield 放在了表达式的右边。我们可以使用.send() 把数据发送给协程函数。

def writer():
  print('-> coroutine started')
  for i in range(8):
    w = yield
    print(i+w)

w = writer()
# 本质还是生成器
>>> w
<generator object writer at 0x000002595BC57468>
# 首先要用next()把协程激活
>>> next(w)
-> coroutine started
# 发送数据
>>> w.send(1)
1
# send到第八次之后会抛出异常
# 因为协程已经结束了
---------------------------------------------------------------------------
StopIteration               Traceback (most recent call last)

第一步必须使用next() 激活协程函数,这样才能在下一步使用.send() 发送数据。

可以看到,在第8次接收完数据之后,会产生结束的异常,因为程序流程结束了,这是正常现象。加个异常处理即可。如果需要在两个协程间传递数据呢?

def writer():
  while True:
    w = yield
    print('>>', w)

def writer_wrapper(coro):
  # 激活
  next(coro)
  while True:
    # 异常处理
    try:
      x = yield
      # 发送数据给writer
      coro.send(x)
    except StopIteration:
      pass
w = writer()
wrap = writer_wrapper(w)
# 激活
next(wrap)
for i in range(4):
  wrap.send(i)
# 输出
>> 0
>> 1
>> 2
>> 3

上面的代码中,数据首先传递到writer_wrapper,之后再传递到writer 。

data——>writer_wrapper——>writer

可以这么写,不过,又要预先激活,又要加异常,看起来有点麻烦啊。yield from 的出现可以解决这个问题,同样是传递数据:

def writer():
  while True:
    w = yield
    print('>>', w)
def writer_wrapper2(coro):
  yield from coro

一行代码解决问题。

总之,yield from相当于提供了一个通道,使得数据可以在协程之间流转 。writer_wrapper2 中使用yield from coro时,coro此时获得控制权,在我们.send() 数据时,writer_wrapper2 被阻塞,直到writer 打印出结果。

在这个阶段,协程本质上还是由生成器构成的。

即使我们使用yield from 简化了流程,协程和生成器的知识理解起来还是有点懵逼,而且yield from 用在异步编程中有诸多不顺(asyncio以前就是用yield from),于是在3.5版本的python中,弃用了yield from ,新加入了两个关键字async 和await ,同时协程不再是生成器类型,而是原生的协程类型。

现在我们定义一个协程要像下面这样:

async def func():
  await 'some code'

不用于异步的协程该怎么用,我还不知道。所以,协程的介绍到这里就结束啦。感谢你对三水点靠木的支持。

Python 相关文章推荐
python实现定制交互式命令行的方法
Jul 03 Python
python连接远程ftp服务器并列出目录下文件的方法
Apr 01 Python
Python实现的数据结构与算法之链表详解
Apr 22 Python
python通过get,post方式发送http请求和接收http响应的方法
May 26 Python
使用python生成杨辉三角形的示例代码
Aug 29 Python
python之当你发现QTimer不能用时的解决方法
Jun 21 Python
节日快乐! Python画一棵圣诞树送给你
Dec 24 Python
Python tkinter和exe打包的方法
Feb 05 Python
Django中Aggregation聚合的基本使用方法
Jul 09 Python
使用numpngw和matplotlib生成png动画的示例代码
Jan 24 Python
python异常中else的实例用法
Jun 15 Python
Python 处理表格进行成绩排序的操作代码
Jul 26 Python
Python实现可自定义大小的截屏功能
Jan 20 #Python
python+matplotlib绘制饼图散点图实例代码
Jan 20 #Python
Python+matplotlib绘制不同大小和颜色散点图实例
Jan 19 #Python
Python搭建FTP服务器的方法示例
Jan 19 #Python
python re模块findall()函数实例解析
Jan 19 #Python
Python enumerate索引迭代代码解析
Jan 19 #Python
5个很好的Python面试题问题答案及分析
Jan 19 #Python
You might like
PHP新手上路(六)
2006/10/09 PHP
php实现从上传文件创建缩略图的方法
2015/04/02 PHP
支持中文、字母、数字的PHP验证码
2015/05/04 PHP
Javascript中的isNaN函数使用说明
2011/11/10 Javascript
五段实用的js高级技巧
2011/12/20 Javascript
jquery自定义类似$.ajax()的方法实现代码
2013/08/13 Javascript
jQuery实现简单倒计时功能的方法
2016/07/04 Javascript
JQuery查找子元素find()和遍历集合each的方法总结
2017/03/07 Javascript
vue2 中如何实现动态表单增删改查实例
2017/06/09 Javascript
vue2利用Bus.js如何实现非父子组件通信详解
2017/08/25 Javascript
React Native使用fetch实现图片上传的示例代码
2018/03/07 Javascript
详解Express笔记之动态渲染HTML(新手入坑)
2018/12/13 Javascript
超详细动手搭建一个VuePress 站点及开启PWA与自动部署的方法
2019/01/27 Javascript
Vue实现table上下移动功能示例
2019/02/21 Javascript
fastadmin中调用js的方法
2019/05/14 Javascript
[02:05:03]完美世界DOTA2联赛循环赛 LBZS VS Matador BO2 10.28
2020/10/28 DOTA
windows下python安装小白入门教程
2018/09/18 Python
详解如何用django实现redirect的几种方法总结
2018/11/22 Python
Python爬取智联招聘数据分析师岗位相关信息的方法
2019/08/13 Python
Python中类似于jquery的pyquery库用法分析
2019/12/02 Python
nginx搭建基于python的web环境的实现步骤
2020/01/03 Python
Python3打包exe代码2种方法实例解析
2020/02/17 Python
Python自动创建Excel并获取内容
2020/09/16 Python
巴西美妆购物网站:Kutiz Beauté
2019/03/13 全球购物
美国Jeep配件购物网站:Morris 4×4 Center
2019/05/01 全球购物
Myprotein荷兰官网:欧洲第一运动营养品牌
2020/07/11 全球购物
测绘工程系学生的自我评价
2013/11/30 职场文书
2014年元旦促销活动方案
2014/02/22 职场文书
初中班主任评语大全
2014/04/24 职场文书
在校大学生自我评价范文
2014/09/12 职场文书
2014年护士个人工作总结
2014/11/11 职场文书
2014年计划生育协会工作总结
2014/11/14 职场文书
春节慰问信范文
2015/02/15 职场文书
2015年医院工作总结范文
2015/04/09 职场文书
2015年思想品德教学工作总结
2015/07/22 职场文书
公司会议开幕词
2016/03/03 职场文书