執行緒在呼叫 Thread.start 之前開始執行
在 Python 中,執行緒允許在單一程式中建立和執行多個執行緒。一個常見的誤解是執行緒在創建後立即開始運行,即使沒有明確呼叫 Thread.start()。然而,事實並非如此。
請考慮以下程式碼片段:
import threading t1 = threading.Thread(target=self.read()) print("something") t2 = threading.Thread(target=self.runChecks(), args=(self,))
在此範例中,建立了兩個執行緒 t1 和 t2,但它們都尚未啟動。 self.read() 函數無限期地運行,這意味著程式永遠不會到達列印行。儘管沒有呼叫 t1.start(),但該行為仍會發生,而 t1.start() 預計會啟動線程,然後繼續執行下一行。
這種意外行為的原因在於 target=self 後面的尾隨括號。讀()。此語法實際上立即呼叫 self.read() 函數並將返回值作為目標參數傳遞給 Thread 建構子。由於Python 期望將函數作為目標傳遞,因此解決方案是刪除尾部括號並明確調用t1.start() 來啟動線程:
import threading t1 = threading.Thread(target=self.read) t1.start() print("something")
或者,如果目標函數需要參數,您可以使用threading .Thread 的args 和kwargs 參數或定義一個lambda 函數來傳遞給建構子。請記住,如果您選擇使用 lambda,它將在調度線程時而不是定義 lambda 時查找函數及其參數。如果在執行緒開始運行之前重新分配任何變量,這可能會導致意外結果。
以上是為什麼我的執行緒在 Python 中呼叫 `Thread.start()` 之前就運行了?的詳細內容。更多資訊請關注PHP中文網其他相關文章!