「Python异步编程-4」-协程的工作流程

协程的工作流程还是挺重要的,能够让我们理解每一步代码的含义。

1.定义/创建协程对象: async / @asyncio.coroutine

2.定义事件循环对象容器: loop = asyncio.get_event_loop()

3.将协程对象转化为task任务(两种方式):
3.1 task = loop.create_task(协程对象), 这种是单个task对象,对应4.1的操作;
3.2 task = asyncio.ensure_future(协程对象), tasks = [task, task...]
这种是多个task对象,对应4.2 的操作。

4.将任务扔进事件循环容器并触发:
4.1 loop.run_until_complete(task)
4.2 多task对象的触发有两种方式:
loop.run_until_complete(asyncio.wait(tasks))
loop.run_until_complete(asyncio.gather(*tasks))

asyncio.gather 和 asyncio.wait 区别:
他们主要是返回值不一样。

async.wait会返回两个值: done和pending。done为已完成的协程Task,pending为超时未完成的协程Task,需通过future.result调用Task的result。

async.gather返回的是已完成Task的result(报错的也会被认为是成功的任务, 一个取消全部取消)

「Python异步编程-1」总览全局
「Python异步编程-2」可迭代对象、迭代器、生成器
「Python异步编程-3」协程、生成器、yield 的联系
「Python异步编程-4」-协程的工作流程

你可能感兴趣的:(「Python异步编程-4」-协程的工作流程)