Python 协程异步实现

        协程(微线程),轻量级线程,其完全由程序自身控制执行流程,而不是操作系统内核调度,这样协程切换开销极小,可以在单线程内实现高并发。在 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资源,提高程序的并发性能。

应用场景:

  1. 异步网络通信:可以将网络请求封装成协程对象,并使用create_task函数将其添加到事件循环中,实现高效的异步网络通信。
  2. 并发任务处理:可以将多个耗时的任务封装成协程对象,并使用create_task函数将它们添加到事件循环中,实现并发执行,提高程序的处理能力。
  3. 异步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密集型计算等),以免阻塞事件循环并降低并发性能。

参考:

Python协程探秘:async/await的魔法_await在协程中的作用-CSDN博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值