Python并發(fā)編程怎樣處理異常

小樊
81
2024-11-02 17:45:32

在Python中,處理并發(fā)編程中的異常需要使用特定的方法。這里有兩種常用的方法來(lái)處理異常:

  1. 使用concurrent.futures.ThreadPoolExecutorconcurrent.futures.ProcessPoolExecutorresult()方法:

當(dāng)使用線程池或進(jìn)程池執(zhí)行任務(wù)時(shí),可以使用result()方法獲取任務(wù)的結(jié)果。如果任務(wù)拋出異常,result()方法會(huì)將其封裝為concurrent.futures.TimeoutErrorconcurrent.futures.ExecutionException。你可以捕獲這些異常并處理原始異常。

示例:

import concurrent.futures
import sys

def raise_exception():
    raise ValueError("An error occurred")

def handle_exception(e):
    print(f"Caught exception: {e}", file=sys.stderr)

with concurrent.futures.ThreadPoolExecutor() as executor:
    future = executor.submit(raise_exception)
    try:
        future.result(timeout=2)
    except concurrent.futures.TimeoutError:
        print("Task timed out", file=sys.stderr)
    except concurrent.futures.ExecutionException as e:
        handle_exception(e.exc_value)
  1. 使用asyncio庫(kù):

在異步編程中,可以使用asyncio.gather()函數(shù)執(zhí)行多個(gè)協(xié)程。如果其中一個(gè)協(xié)程拋出異常,asyncio.gather()會(huì)將其傳遞給asyncio.gather()return_exceptions參數(shù)。你可以設(shè)置return_exceptionsTrue,然后使用try-except語(yǔ)句捕獲異常。

示例:

import asyncio

async def raise_exception():
    raise ValueError("An error occurred")

async def main():
    tasks = [raise_exception()]
    results = await asyncio.gather(*tasks, return_exceptions=True)

    for result in results:
        if isinstance(result, Exception):
            print(f"Caught exception: {result}", file=sys.stderr)
        else:
            print(f"Result: {result}")

asyncio.run(main())

這兩種方法都可以幫助你在Python并發(fā)編程中處理異常。你可以根據(jù)自己的需求和場(chǎng)景選擇合適的方法。

0