部分待掌握概念
event_loop 事件循环:程序开启一个无限的循环,程序员会把一些函数注册到事件循环上。当满足事件发生的时候,调用相应的协程函数。
coroutine 协程:协程对象,指一个使用async关键字定义的函数,它的调用不会立即执行函数,而是会返回一个协程对象。协程对象需要注册到事件循环,由事件循环调用。
task 任务:一个协程对象就是一个原生可以挂起的函数,任务则是对协程进一步封装,其中包含任务的各种状态。
future: 代表将来执行或没有执行的任务的结果。它和task上没有本质的区别
async/await 关键字:python3.5 用于定义协程的关键字,async定义一个协程,await用于挂起阻塞的异步调用接口。
协程:单件事执行的事件并没有减少,但是异步执行时间减少,看电视半小时,烧水半小时,在看电视的同时烧水,共用半小时。异步就是看着水还没烧开,烧着水,等待水烧开的状态时,看电视
协程格式
#
import time
import asyncio
now = lambda : time.time()
#①定义协程函数
async def do_some_work(x):
print('Waiting: ', x)
asyncio.sleep(1)
start = now()
#②生成一个协程
coroutine = do_some_work(2)
#③产生一个事件循环
loop = asyncio.get_event_loop()
#④把要检测的事情加进来,或者说把任务加进来
loop.run_until_complete(coroutine)
print('TIME: ', now() - start)
协程格式2:(多coroutine)
import asyncio
import time
now = lambda: time.time()
#①注册协程函数
async def do_some_work(x):
print('Waiting: ', x)
await asyncio.sleep(x)
return 'Done after {}s'.format(x)
start = now()
#②生成协程
coroutine1 = do_some_work(1)
coroutine2 = do_some_work(2)
coroutine3 = do_some_work(4)
#③生成协程任务
tasks = [
asyncio.ensure_future(coroutine1),
asyncio.ensure_future(coroutine2),
asyncio.ensure_future(coroutine3)
]
#④注册事件循环
loop = asyncio.get_event_loop() # 事件循环
#⑤注册三件事情
loop.run_until_complete(asyncio.wait(tasks)) # 注册3件事情
#⑥取出协程任务结果
for task in tasks:
print('Task ret: ', task.result())
print('TIME: ', now() - start)