首頁 > 後端開發 > Python教學 > 如何使用多重處理並行運行 Python 函數?

如何使用多重處理並行運行 Python 函數?

Susan Sarandon
發布: 2024-11-29 20:07:13
原創
214 人瀏覽過

How Can I Run Python Functions in Parallel Using Multiprocessing?

函數的並行執行

在Python中,函數的順序執行是預設行為。但是,在處理資源密集型操作時,同時執行多個函數以提高效能可能是有益的。本文討論如何使用執行緒或多處理並行運行函數。

執行緒和多處理是分別為多執行緒和多進程場景提供機制的兩個函式庫。雖然執行緒更加輕量級,但多處理通常可以為運算任務提供更好的效能。

讓我們考慮一個範例,我們要並行執行兩個函數 func1 和 func2。使用多處理,我們可以將函數定義為:

def func1():
    # Function 1 code
    print("func1: completing")


def func2():
    # Function 2 code
    print("func2: completing")
登入後複製

要並行運行函數,我們可以使用以下方法:

from multiprocessing import Process

p1 = Process(target=func1)
p1.start()
p2 = Process(target=func2)
p2.start()
登入後複製

start() 方法啟動進程,並且它們同時執行。為了確保我們的主程序等待子程序完成,我們可以使用join() 方法:

p1.join()
p2.join()
登入後複製

此外,我們可以將並行執行封裝到輔助函數中:

def runInParallel(*fns):
    proc = []
    for fn in fns:
        p = Process(target=fn)
        p.start()
        proc.append(p)
    for p in proc:
        p.join()

runInParallel(func1, func2)
登入後複製

這使我們能夠透過簡單簡潔的函數呼叫並行運行多個函數。

以上是如何使用多重處理並行運行 Python 函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板