异步函数与异步生成器

异步函数介绍

定义:使用 async def 关键字定义的函数,可以暂停执行并在稍后恢复

特点:函数内部可以使用 await 关键字等待其他异步操作完成

返回值:调用时返回协程对象(coroutine),而不是直接执行函数体

性能方面:

  • I/O 密集型:异步并发优势明显
  • CPU 密集型:对于计算密集型任务,异步并不能带来性能提升

其它:避免在异步函数中使用阻塞操作,如 time.sleep(),使用异步版本的操作,如 await asyncio.sleep()

定义

复制代码
async def function_name(parameters):
    # 异步函数体
    await some_async_operation()
    return result

定义要点

  • 使用 async def 替代普通函数的 def
  • 函数内部可以使用 await 关键字
  • 可以使用 return 返回值

调用

在异步环境中调用

  • 使用 await:在另一个异步函数中使用 await function_name()
  • 返回协程对象:直接调用 function_name() 返回协程对象

在同步环境中调用

  • 使用 asyncio.run():asyncio.run(function_name())
  • 创建事件循环:手动创建和管理事件循环

示例

同步环境中调用:asyncio.run

示例:

复制代码
async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


res = hello()
print(res, type(res))

输出结果

复制代码
<coroutine object hello at 0x0000023CA3CA5B40> <class 'coroutine'>
<sys>:0: RuntimeWarning: coroutine 'hello' was never awaited

上面直接调用异步函数hello()会返回一个协程对象,而不是执行函数

修改:asyncio.run()是运行异步函数的标准方式

复制代码
import asyncio


async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


res = hello()
print(res, type(res))
res2 = asyncio.run(res)
print(res2, type(res2))

输出结果:

复制代码
<coroutine object hello at 0x00000216F8162680> <class 'coroutine'>
全栈测试笔记
qzcsbj <class 'str'>

优化

复制代码
import asyncio


async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


if __name__ == "__main__":
    res = hello()
    print(res, type(res))
    res2 = asyncio.run(res)
    print(res2, type(res2))

执行流程:

  • asyncio.run(hello()) 直接启动事件循环
  • 直接执行 hello() 函数并返回结果
  • 简洁的单函数执行模
异步环境中调用:await
复制代码
import asyncio


async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


async def call_hello():
    res = hello()
    print(res, type(res))
    res2 = await res  # await res等价于await hello()
    print(res2, type(res2))


if __name__ == "__main__":
    # call_hello()  # 报错:coroutine 'call_hello' was never awaited call_hello()
    asyncio.run(call_hello())

输出结果:

复制代码
<coroutine object hello at 0x0000023816222680> <class 'coroutine'>
全栈测试笔记
qzcsbj <class 'str'>

执行流程:

  • asyncio.run(call_hello()) 启动事件循环
  • call_hello() 内部先获取 hello() 的协程对象
  • 通过 await 等待协程执行完成
  • 演示了协程对象的创建和等待过程

异步生成器

参考:https://www.cnblogs.com/uncleyong/p/6208547.html

相关推荐
misL NITL10 分钟前
mysql之如何获知版本
数据库·mysql
许彰午23 分钟前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
寒山李白26 分钟前
解决 python-docx 生成的 Word 文档打开时弹出“无法读取内容“警告
python·word·wps·文档·docx·qoder
星马梦缘28 分钟前
如何切换window-ubuntu双系统【方案二】
linux·运维·ubuntu
陈随易30 分钟前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
2401_832365521 小时前
JavaScript中rest参数(...args)取代arguments的优势
jvm·数据库·python
Sirius.z1 小时前
第J3周:DenseNet121算法详解
python
2301_779622412 小时前
Go语言怎么用信号量控制并发_Go语言semaphore信号量教程【入门】
jvm·数据库·python
丑八怪大丑2 小时前
Java网络编程
linux·服务器·网络
2301_766283442 小时前
c++如何将控制台输出保存到文件_cout重定向到txt【详解】
jvm·数据库·python