非同步並行化獨立 Python 函數的最佳方法是什麼?
Python 中的平行程式設計:綜合指南
對於 C 語言,OpenMP 提供了一個簡單的平行程式碼機制。然而,Python 用戶在尋求類似功能時面臨挑戰。本指南旨在透過提出針對 Python 量身定制的解決方案來應對這些挑戰,使程式設計師能夠利用並行處理的力量來優化其程式碼。
具體來說,我們將探索一個涉及兩個獨立函數的場景,solve1(A ) 和solve2(B),需要並行執行而不是順序執行。提供的範例程式碼突顯了這些函數:
<code class="python">def solve(Q, G, n): ... setinneropt, partition, x = setinner(Q, G, n) ... if ... node1 = partition[0] node2 = partition[1] ...</code>
這裡的關鍵函數是 setinner 和 setouter,代表我們旨在並行化的獨立任務。
建議的方法是利用 Python 的多處理模組,特別是它的處理池。這些池採用通用工作進程,為電腦上的每個 CPU 核心分配一個工作進程。因此,多個工作進程可以同時執行已指派的平行任務。
對於我們的特定場景,程式碼將如下所示:
<code class="python">from multiprocessing import Pool pool = Pool() result1 = pool.apply_async(setinner, [Q, G, n]) # Evaluate "setinner(Q, G, n)" asynchronously result2 = pool.apply_async(setouter, [Q, G, n]) # Evaluate "setouter(Q, G, n)" asynchronously answer1 = result1.get(timeout=10) answer2 = result2.get(timeout=10)</code>
透過建立處理池,我們實質上委託了執行這些獨立的函數來分離進程,有效地實現並行處理。
需要注意的是,在Python中使用執行緒進行平行程式設計是不可取的,因為全域解釋器鎖定(GIL)會禁止同時操作Python 物件。因此,對於 Python 的平行程式設計工作,建議使用進程而不是執行緒。
以上是非同步並行化獨立 Python 函數的最佳方法是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

攻克Investing.com的反爬蟲策略許多人嘗試爬取Investing.com(https://cn.investing.com/news/latest-news)的新聞數據時,常常�...

Python3.6環境下加載pickle文件報錯:ModuleNotFoundError:Nomodulenamed...

使用Scapy爬蟲時管道文件無法寫入的原因探討在學習和使用Scapy爬蟲進行數據持久化存儲時,可能會遇到管道文�...
