协程(微线程),轻量级线程,其完全由程序自身控制执行流程,而不是操作系统内核调度,这样协程切换开销极小,可以在单线程内实现高并发。在 Python 中,协程通过async/await关键字实现。async 可定义异步函数,await 用在异步函数中等待一个异步操作(如I/O操作)的完成。
使用 async 定义的函数称为异步函数,异步函数内部可用 await表示
等待异步操作(如网络请求、文件读写等)的完成。等待期间,函数会挂起,控制权给其他任务,实现并发执行。
在异步函数中,使用 await 等待一个异步操作的完成。await后面通常跟一个异步调用表达式(如await some_async_function()),该表达式会返回一个Future或Awaitable对象。当这个对象表示的操作完成时,await表达式会恢复执行,并返回操作的结果。
create_task()
Asyncio create_task是 Python 中的一个函数,将一个协程对象加入到事件循环异步执行。作用是创建一个任务,并将任务添加到事件循环中,使得任务可以被调度执行。
使用asyncio 异步编程时,会创建协程对象来表示一个异步任务。使用create_task函数将这个协程对象封装成一个任务,并将任务添加到事件循环中。任务会在事件循环中被调度执行,而不会阻塞当前线程的执行。
create_task函数可以方便地管理和调度异步任务。通过将协程对象封装成任务,在需要的时候随时取消任务、获取任务的状态、等待任务完成等操作。任务是在事件循环中执行,可以充分利用CPU资源,提高程序的并发性能。
应用场景:
- 异步网络通信:可以将网络请求封装成协程对象,并使用create_task函数将其添加到事件循环中,实现高效的异步网络通信。
- 并发任务处理:可以将多个耗时的任务封装成协程对象,并使用create_task函数将它们添加到事件循环中,实现并发执行,提高程序的处理能力。
- 异步IO操作:可以将需要进行异步IO操作的任务封装成协程对象,并使用create_task函数将其添加到事件循环中,实现高效的异步IO操作。
等同于 python3.7之前的 ensure_future()。
import asyncio async def delay_demo(sleep_time): print(f"start delay {sleep_time}") await asyncio.sleep(sleep_time) print(f"end delay {sleep_time}") async def main(): tasks = [delay_demo(2), delay_demo(1), delay_demo(3)] await asyncio.gather(*tasks) asyncio.run(main()) 输出结果: start delay 2 start delay 1 start delay 3 end delay 1 end delay 2 end delay 3
上述代码实现了并发执行,异步操作由事件循环(Event Loop)调度和管理,不断检查是否有已完成的异步操作,恢复相应的异步函数执行,在一个线程内实现高并发,充分利用系统资源。
注意,在异步函数中,应尽量避免使用阻塞操作(如同步I/O、CPU密集型计算等),以免阻塞事件循环并降低并发性能。
参考: