為什麼 Python 多重處理會失敗並出現「PicklingError: Can't pickle」以及如何修復它?
Dec 08, 2024 pm 08:33 PM「PicklingError:無法pickle 」故障排除在Python Multiprocessing
當嘗試使用Python的多處理模組時,你可能會遇到“PicklingError: Can't pickle
理解 Pickling
Pickling 是將物件轉換為物件的流程二進位流,允許儲存並稍後重新建立。在多重處理中,任務透過佇列在網路上傳輸,因此它們必須是可挑選的。
函數和頂層定義
在頂層定義的常規函數模組本質上是可醃製的。但是,在類別或其他巢狀函數中定義的函數則不然。這是因為在 pickling 過程中遇到的「全域變數」可能與創建它們的過程中的不同。
不可Picklable 函數的範例
考慮以下程式碼定義了巢狀在類別方法中的函數:
class Foo: def g(self): def h(): pass h()
登入後複製
呼叫pool.apply_async (Foo().g) 將導致“PicklingError”,因為巢狀函數h 未在頂層定義。
解決方案
至解決這個問題,只需在模組的頂層定義函數並從嵌套函數中調用它即可。例如:
def g(foo): def h(): pass h() foo.work()
登入後複製
現在,pool.apply_async(g, args=(Foo(),)) 會正常運作。
以上是為什麼 Python 多重處理會失敗並出現「PicklingError: Can't pickle」以及如何修復它?的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章標籤

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

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

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

Dreamweaver CS6
視覺化網頁開發工具

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