首页 > 编程问答 >同时运行多个异步阻塞函数 - Python

同时运行多个异步阻塞函数 - Python

时间:2024-08-09 03:29:32浏览次数:14  
标签:python multithreading python-asyncio coroutine concurrent-processing

我是 Python 和协程的新手,我正在尝试利用 Python 的 asyncio 库来并行处理阻塞函数。我正在使用 python 3.8.6。我有一个阻塞函数,它从数组输入中接收不同的输入,我需要每个输入的阻塞函数同时运行。我已经尝试过,但它们似乎仍然按顺序运行:

async def main():
    tasks = [asyncio.create_task(blocking_function(input)) for input in inputs]
    result = await asyncio.gather(*tasks)
    print(result)

你理解了使用 asyncio.create_task asyncio.gather 并行运行任务的基本思想。但是, asyncio 只在异步操作之间进行协作多任务处理。如果你的 blocking_function 包含同步阻塞代码,它将阻塞事件循环,从而阻止其他任务运行。

为了实现真正的并行,你需要将阻塞操作移到线程池或单独的进程中。这里有两个选择:

1. 使用 loop.run_in_executor 和线程池:

这允许你在一个单独的线程中运行阻塞函数,将事件循环释放出来处理其他任务。

```python import asyncio from concurrent.futures import ThreadPoolExecutor

async def main(): loop = asyncio.get_running_loop() with ThreadPoolExecutor() as pool: tasks = [loop.run_in_executor(pool, blocking_function, input) for input in inputs] result = await asyncio.gather(*tasks) print(result)

def blocking_function(input): # 模拟阻塞操作 time.sleep(1) return input * 2

asyncio.run(main()) ```

  • 我们获取当前正在运行的事件循环 ( asyncio.get_running_loop() ).
  • 我们创建一个 ThreadPoolExecutor 来管理线程。
  • 我们使用 loop.run_in_executor 在线程池中运行 blocking_function 。这返回一个 asyncio.Future 对象,我们可以像任何其他异步任务一样等待它。

2. 使用 asyncio.to_thread (Python 3.9+):

Python 3.9 引入了一个更方便的函数 asyncio.to_thread ,它简化了将函数卸载到线程的过程。

```python import asyncio

async def main(): tasks = [asyncio.to_thread(blocking_function, input) for input in inputs] result = await asyncio.gather(*tasks) print(result)

def blocking_function(input): # 模拟阻塞操作 time.sleep(1) return input * 2

asyncio.run(main()) ```

  • asyncio.to_thread 在一个单独的线程中运行 blocking_function 并返回一个 asyncio.Future

选择哪种方法取决于你的 Python 版本以及你对线程池的控制程度。对于大多数情况, asyncio.to_thread 更简单直接。如果需要更精细的控制线程池,可以使用 loop.run_in_executor

请记住,使用线程或进程会增加程序的复杂性。确保你理解并行编程的潜在问题,例如竞争条件,并在必要时使用适当的同步机制。

标签:python,multithreading,python-asyncio,coroutine,concurrent-processing
From: 78849969

相关文章

  • 使用两个连接的字符串调用变量 Python
    抱歉缺乏细节,因为我是python的初学者:c1=c2=c3=c4=c5=Falsex=int(input("Enteranumber1-5:"))ifx>5orx<1:print("Yournumbermustbebetween1and5")else:"c",x=True第8行是连接2个字符串的地方。我不确定......
  • 测试Python中是否存在可执行文件?
    在Python中,有没有一种可移植且简单的方法来测试可执行程序是否存在?简单我的意思是类似which命令的东西,这将是完美的。我不想手动搜索PATH或涉及尝试使用Popen&al执行它并查看它是否失败(这就是我现在正在做的事情,但想象它是launchmissiles)......
  • Python 和 Excel:将数据放入另一个函数中,然后从中获取信息
    我正在尝试将温度/压力数据放入蒸汽表以获得过热焓数据。我已经成功地获取了数据并将其放入Excel文件中,然后它为我提取了焓数据。问题是,当我将温度和压力数据放入蒸汽表时,它实际上并没有进行双重插值,因此焓(H)值实际上从未改变ng。我最终只得到了蒸汽数据中给出......
  • Python 类型提示:显式排除无效的重载组合?
    我有一个带有两个参数的函数,每个参数都可以采用两种类型之一。四个成对组合中的三个有效,但第四个无效。我想找到一种方法来键入提示此场景,可以检查这些类型,但不一定每次调用foo()时都必须编写代码来检查无效情况。有没有办法可以改进foo()、bar()或两......
  • 我在制作 python 语音应用程序时遇到错误
    我编写了一个语音聊天应用程序代码,但是当我们运行此代码并加入语音频道时,我收到照片中的错误错误1错误2这是我的代码;客户端代码:importtkinterastkfromtkinterimportmessageboximportpyaudioimportsocketimportthreadingimporttimeHOST=......
  • pyocr,一个超酷的Python库!
    pyocr是一个用于光学字符识别(OCR)的Python库,它提供了一个简单的接口,允许开发者将图片中的文本提取出来。这个库是对Tesseract-OCR的封装,使得在Python环境中使用OCR技术变得更加便捷。如何安装pyocr首先,要使用pyocr库,您需要安装它。可以使用pip包管理工具来进......
  • pattern,一款超牛的Python库
    在程序开发中,处理文本数据和进行自然语言处理是常见需求。pattern是一个强大的Python库,专为文本分析而设计,提供了丰富的功能,包括自然语言处理、数据挖掘和网络分析等。它简单易用,让程序员能够快速实现复杂的文本处理任务。如何安装pattern在开始使用pattern库之前,首先......
  • 【Playwright+Python】系列教程(八)鉴权Authentication的使用
    写在前面还是有些絮叨的感觉,官方翻译和某些博主写那个玩楞,基本都是软件直接翻译后的产物。读起来生硬不说,甚至有的时候不到是什么意思,真的是实在不敢恭维。到底是什么意思?就是你已经登陆过一次,在Session、Cookie未失效的情况下,登录过一次后,下次就不用再走一遍登录的过程,从而缩......
  • 基于CNN-GRU-Attention混合神经网络的负荷预测方法(Python代码实现)
    ......
  • Python和AI库NumPy(二):数组创建与操作的深入探索
    目录1.数组创建1.1基本数组创建1.2使用内置函数创建数组1.3特殊数组的创建2.数组的基本操作2.1数组属性2.2数组索引和切片2.3数组的形状操作2.4数组拼接与分割3.数组的数学操作3.1基本算术操作3.2广播机制3.3线性代数运算4.高级数组操作4.1花式......