Asyncio
Python 在 3.4 中引入了协程的概念,3.5 确定了协程的语法,Asyncio 基本概念:
- Event Loop 事件循环:程序开启一个 While True
循环,用户将一些函数注册到事件循环上,当满足事件执行条件时,调用的协程函数; - Coroutine 协程对象:使用
asnc关键字定义的函数,它的调用不会立即执行函数,而是返回一个协程对象,协程对象需要注册到事件循环中,由事件循环负责调用; - Task:对协程对象的进一步封装,包括任务的各种状态;
- Future:代表将来执行或没有执行的任务的结果,和 Task 没有本质的区别;
- async:定义一个协程对象;
- await:挂起阻塞的异步调用接口;
tips : 使用 Cython + libuv 实现的 uvloop 可以提升事件循环更多的性能:
import asyncio
import uvloop
# 声明使用 uvloop 事件循环
asyncio.set_event_loop_policy(uvloop.EventLoopPolicy())
loop = uvloop.new_event_loop()
asyncio.set_event_loop(loop)