1.1 asyncio简介
参考博客:https://www.cnblogs.com/zhaof/p/8490045.html
1、什么是asyncio?
1.和我们以前常用的gevent模块相似,asyncio模块也是在Python中实现协程的模块
2.区别是gevent是第三方库,通过greenlet实现协程,遇到I/O自动切换(自动挡)
3.asyncio是Python 3.4版本引入的标准库,asycio 需要自己在代码中让出CPU,控制权在自己手上(手动挡)
4. asyncio是原生协程关键字:Async和Await,它们的底层基于生成器函数
2、asyncio应用场景
1. 在程序在执行 IO 密集型任务的时候,程序会因为等待 IO 而阻塞。
2. 协程遇到io操作而阻塞时,立即切换到别的任务,如果操作完成则进行回调返回执行结果
3、asyncio的一些关键字的说明
1. event_loop 事件循环:程序开启一个无限循环,把一些函数注册到事件循环上,当满足事件发生的时候,调用相应的协程函数
2. coroutine 协程:协程对象,指一个使用async关键字定义的函数,它的调用不会立即执行函数,而是会返回一个协程对象。协程对象需要注册到事件循环,由事件循环调用。
3. task 任务:一个协程对象就是一个原生可以挂起的函数,任务则是对协程进一步封装,其中包含了任务的各种状态
4. future: 代表将来执行或没有执行的任务的结果。它和task上没有本质上的区别
5. async/await 关键字:python3.5用于定义协程的关键字,async定义一个协程,await用于挂起阻塞的异步调用接口。
1.2 asyncio基本使用
1、定义协程并创建tasks
1. 在上面带中我们通过async关键字定义一个协程(coroutine),当然协程不能直接运行,需要将协程加入到事件循环loop中
2. asyncio.get_event_loop:创建一个事件循环,然后使用run_until_complete将协程注册到事件循环,并启动事件循环
3. 协程对象不能直接运行,在注册事件循环的时候,其实是run_until_complete方法将协程包装成为了一个任务(task)对象.
4. task对象是Future类的子类,保存了协程运行后的状态,用于未来获取协程的结果
import asyncio import time # 我们通过async关键字定义一个协程,当然协程不能直接运行,需要将协程加入到事件循环loop中 async def do_some_work(x): print("waiting:", x) start = time.time() coroutine = do_some_work(2) loop = asyncio.get_event_loop() # asyncio.get_event_loop:创建一个事件循环 # 通过loop.create_task(coroutine)创建task,同样的可以通过 asyncio.ensure_future(coroutine)创建task task = loop.create_task(coroutine) # 创建任务, 不立即执行 loop.run_until_complete(task) # 使用run_until_complete将协程注册到事件循环,并启动事件循环 print("Time:",time.time() - start)