协程 - 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的更多相关文章

  1. Python 协程总结

    Python 协程总结 理解 协程,又称为微线程,看上去像是子程序,但是它和子程序又不太一样,它在执行的过程中,可以在中断当前的子程序后去执行别的子程序,再返回来执行之前的子程序,但是它的相关信息还是 ...

  2. [转载] Python协程从零开始到放弃

    Python协程从零开始到放弃 Web安全 作者:美丽联合安全MLSRC   2017-10-09  3,973   Author: lightless@Meili-inc Date: 2017100 ...

  3. python 协程与go协程的区别

    进程.线程和协程 进程的定义: 进程,是计算机中已运行程序的实体.程序本身只是指令.数据及其组织形式的描述,进程才是程序的真正运行实例. 线程的定义: 操作系统能够进行运算调度的最小单位.它被包含在进 ...

  4. day-5 python协程与I/O编程深入浅出

    基于python编程语言环境,重新学习了一遍操作系统IO编程基本知识,同时也学习了什么是协程,通过实际编程,了解进程+协程的优势. 一.python协程编程实现 1.  什么是协程(以下内容来自维基百 ...

  5. 终结python协程----从yield到actor模型的实现

    把应用程序的代码分为多个代码块,正常情况代码自上而下顺序执行.如果代码块A运行过程中,能够切换执行代码块B,又能够从代码块B再切换回去继续执行代码块A,这就实现了协程 我们知道线程的调度(线程上下文切 ...

  6. 从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 ...

  7. 关于python协程中aiorwlock 使用问题

    最近工作中多个项目都开始用asyncio aiohttp aiomysql aioredis ,其实也是更好的用python的协程,但是使用的过程中也是遇到了很多问题,最近遇到的就是 关于aiorwl ...

  8. 用yield实现python协程

    刚刚介绍了pythonyield关键字,趁热打铁,现在来了解一下yield实现协程. 引用官方的说法: 与线程相比,协程更轻量.一个python线程大概占用8M内存,而一个协程只占用1KB不到内存.协 ...

  9. 00.用 yield 实现 Python 协程

    来源:Python与数据分析 链接: https://mp.weixin.qq.com/s/GrU6C-x4K0WBNPYNJBCrMw 什么是协程 引用官方的说法: 协程是一种用户态的轻量级线程,协 ...

随机推荐

  1. CI框架获取post和get参数_CodeIgniter使用心得

    请参考:CI文档的输入类部分: $this->input->post()$this->input->get() -------------------------------- ...

  2. 代码注释规范-IDEA 配置 Java 类方法注释模板

    1. 引言     团队开发时,业务模块分配的越清晰,代码注释管理越完善,越有利于后面维护,后面再管理也方便不少.另外也起着"文字砖"的作用,你懂的.注释不需要很详细,把代码块方法 ...

  3. Java 基础(一)| 使用泛型的正确姿势

    前言 为跳槽面试做准备,今天开始进入 Java 基础的复习.希望基础不好的同学看完这篇文章,能掌握泛型,而基础好的同学权当复习,希望看完这篇文章能够起一点你的青涩记忆. 一.什么是泛型 泛型,即&qu ...

  4. pair 数组

    当有两个元素需要绑定在一起的时候可以用结构体 , 此时也可以用 pair 数组去替代结构体 . 定义 : pair<int, double> p1; //使用默认构造函数 pair< ...

  5. sender e

    sender 产生事件的对象e 事件的参数

  6. 使用read、readline、readlines和pd.read_csv、pd.read_table、pd.read_fwf、pd.read_excel获取数据

    从文本文件读取数据 法一: 使用read.readline.readlines读取数据 read([size]):从文件读取指定的字节数.如果未给定或为负值,则去取全部.返回数据类型为字符串(将所有行 ...

  7. python专题文件操作

    一 前言 本篇文章主要对文件操作进行说明,知识追寻者创作必属精品,读完本篇你将获得基础的文件操作能力,深入理解文件操作API,基础真的很重要,不管学什么知识,故看知识追寻者的专题系列真的很不错. 二 ...

  8. MySQL多表联查以及以及架构

    多表之间关联查询:      据库操作中,多表联合查询是后台开发者常用到的查询语句. JOIN SQL JOIN 子句用于把来自两个或多个表的行结合起来,最常见的 JOIN 类型:SQL INNER ...

  9. jade 的 考古

    Jade是一款高性能简洁易懂的模板引擎(加上这两个字我想起了发动机,为什么不直接叫发动机呢), Jade是Haml的Javascript实现, 在服务端(NodeJS)及客户端均有支持. haml 是 ...

  10. Windows版Redis主从配置

    一.下载 从github上下载Redis的zip包,地址:https://github.com/MicrosoftArchive/redis/releases Redis本身不支持windows,这是 ...