Python 协程 - Coroutines
协程 - Coroutines
Awaitable Objects,
Awaitable Objects 通常由 __await__() 生成, 而
Coroutine objects 是由 async def 关键字定义的函数 return 的 Awaitable Objects.
Note,
被 types.coroutine() or asyncio.coroutine() 装饰的生成器迭代器对象(generator iterator objects)
是没有通过 __await__() 生成的 Awaitable Objects. object.__await__(self) 必须 return 一个 iterator, 用来生成 Awaitable Objects.
如, asyncio.Future 执行这个方法一兼容 await 表达式.
See also PEP 492 for additional information about awaitable objects. Coroutine Objects,
Coroutine objects 是 awaitable objects, 是一个 __await__() return 的 iterator,
Coroutine 的执行就是对 __await__() return 的 iterator 的迭代. 跟 iterator 一样,
当 coroutine 执行完毕后 raises StopIteration, 这个异常的 value 属性是执行返回的结果.
如果 coroutine raises an exception, 这个异常会被'冒泡式' 返回. Coroutines 不可以直接
raise 一个未加工过的 StopIteration exceptions. Coroutines 有如下方法(与 generator 相似), 但是与 generators 不同的是 coroutines 不对
迭代提供直接的支持. Python version 3.5.2, 之后 在一个 coroutine 上多次 await 返回
RuntimeError exception. coroutine.send(value)
开始或者恢复 coroutine 的执行. 如果参数 value = None, 为对 coroutine 的预激活.
若 value 不是 None, 这个方法相当于 iterator 的 send() 方法, 将使 coroutine 暂停.
方法的返回 (return value, StopIteration, or other exception) 上面已经描述过. coroutine.throw(type[, value[, traceback]])
在 coroutine raise specified exception.
这个方法对应 iterator 中的 throw() 方法, 会使 coroutine 暂停 coroutine.close()
使 coroutine 去初始化并退出. 对应 iterator 的 close() 方法. Asynchronous Iterators
一个 asynchronous iterable 通过调用 __aiter__() 得到一个 asynchronous iterator.
Asynchronous iterators 可以被用在一个 async 声明中. object.__aiter__(self)
返回一个 asynchronous iterator 对象. object.__anext__(self)
从 iterator 中返回一个 awaitable 对象. 当 iterator 结束的时候
raise StopAsyncIteration error exception asynchronous iterable object 的例子, class Reader:
async def readline(self):
... def __aiter__(self):
return self async def __anext__(self):
val = await self.readline()
if val == b'':
raise StopAsyncIteration
return val Asynchronous Context Managers,
asynchronous context manager 是一个能够暂停执行的 context manager .
Asynchronous context managers 可以通过 async with 关键字声明.
object.__aenter__(self)
与 __enter__() 类似, 不同之处在于 方法必须返回一个 awaitable 对象. object.__aexit__(self, exc_type, exc_value, traceback),
与 __exit__() 类似, 不同之处在于 方法必须返回一个 awaitable 对象. asynchronous context manager 的例子,
class AsyncContextManager:
async def __aenter__(self):
await log('entering context') async def __aexit__(self, exc_type, exc, tb):
await log('exiting context') Reference,
Python doc. https://docs.python.org/3/reference/datamodel.html#coroutines
Python 协程 - Coroutines的更多相关文章
- Python 协程总结
Python 协程总结 理解 协程,又称为微线程,看上去像是子程序,但是它和子程序又不太一样,它在执行的过程中,可以在中断当前的子程序后去执行别的子程序,再返回来执行之前的子程序,但是它的相关信息还是 ...
- [转载] Python协程从零开始到放弃
Python协程从零开始到放弃 Web安全 作者:美丽联合安全MLSRC 2017-10-09 3,973 Author: lightless@Meili-inc Date: 2017100 ...
- python 协程与go协程的区别
进程.线程和协程 进程的定义: 进程,是计算机中已运行程序的实体.程序本身只是指令.数据及其组织形式的描述,进程才是程序的真正运行实例. 线程的定义: 操作系统能够进行运算调度的最小单位.它被包含在进 ...
- day-5 python协程与I/O编程深入浅出
基于python编程语言环境,重新学习了一遍操作系统IO编程基本知识,同时也学习了什么是协程,通过实际编程,了解进程+协程的优势. 一.python协程编程实现 1. 什么是协程(以下内容来自维基百 ...
- 终结python协程----从yield到actor模型的实现
把应用程序的代码分为多个代码块,正常情况代码自上而下顺序执行.如果代码块A运行过程中,能够切换执行代码块B,又能够从代码块B再切换回去继续执行代码块A,这就实现了协程 我们知道线程的调度(线程上下文切 ...
- 从yield 到yield from再到python协程
yield 关键字 def fib(): a, b = 0, 1 while 1: yield b a, b = b, a+b yield 是在:PEP 255 -- Simple Generator ...
- 关于python协程中aiorwlock 使用问题
最近工作中多个项目都开始用asyncio aiohttp aiomysql aioredis ,其实也是更好的用python的协程,但是使用的过程中也是遇到了很多问题,最近遇到的就是 关于aiorwl ...
- 用yield实现python协程
刚刚介绍了pythonyield关键字,趁热打铁,现在来了解一下yield实现协程. 引用官方的说法: 与线程相比,协程更轻量.一个python线程大概占用8M内存,而一个协程只占用1KB不到内存.协 ...
- 00.用 yield 实现 Python 协程
来源:Python与数据分析 链接: https://mp.weixin.qq.com/s/GrU6C-x4K0WBNPYNJBCrMw 什么是协程 引用官方的说法: 协程是一种用户态的轻量级线程,协 ...
随机推荐
- TensorFlow——常见张量操作的API函数
1.张量 张量可以说是TensorFlow的标志,因为整个框架的名称TensorFlow就是张量流的意思,全面的认识一下张量.在TensorFlow程序使用tensor数据结构来代表所有的数据,在计算 ...
- Java Linked集合的简单介绍和常用方法的使用
LinkedList的简单介绍 java.util.LinkedList 集合数据存储的结构是链表结构.LinkedList是一个双向链表在实际开发中,对一个集合元素的添加和删除,经常涉及到首尾操作, ...
- python检查是否是闰年
检查的依据: 闰年可以被4整除不能被100整除,或者可以被400整除. year = int(input("请输入年份:")) if year % 4 == 0 and year ...
- (2)MongoDB副本集自动故障转移原理
前文我们搭建MongoDB三成员副本集,了解集群基本特性,今天我们围绕下图聊一聊背后的细节. 默认搭建的replica set均在主节点读写,辅助节点冗余部署,形成高可用和备份, 具备自动故障转移的能 ...
- nacos-docker安装nacos并配置数据库
拉取nacos/nacos-server镜像 docker pull nacos/nacos-server 配置数据库(MySQL) 创建存储nacos配置的数据库 create database n ...
- 如何配置好Selenium2Library的环境
1.首先是下载如下文件 1,ActivePython-其自带了pip工具,很方便,记得选择activepython是2.7x版本的python: 2.依次安装wxpython,Robotframewo ...
- python 进程事件
1.作用 通过信号量,控制全部进程进入阻塞状态,也可以通过控制信号量,解除全部进程的阻塞 注意:定义的事件对象,默认状态是阻塞 2.常用方法 """ 对象.set() 作 ...
- 约束路由 用正则表达式约束路由 Constraining a Route Using a Regular Expression 精通ASP-NET-MVC-5-弗瑞曼
- Java基础系列1:深入理解Java数据类型
Java基础系列1:深入理解Java数据类型 当初学习计算机的时候,教科书中对程序的定义是:程序=数据结构+算法,Java基础系列第一篇就聊聊Java中的数据类型. 本篇聊Java数据类型主要包括四个 ...
- 用ES7解决异步回调地狱问题
用了 Promise 其实并没有真正解决回调地狱问题,并且还新增了很多 .then(data => { .... }) 这些很没有意义的 “模板代码”.所以先人们又搞出了generator 和 ...