上一篇文章:Python執行緒專題7:條件變數
下一篇文章:Python執行緒專題9:執行緒終止與掛起
使用諸如Lock、RLock、Semphore之類的鎖原語時,必須多加小心,鎖的錯誤使用很容易導致死鎖或相互競爭。依賴鎖的程式碼應該保證當出現異常時可以正常的釋放鎖。
典型程式碼如下:
try:
lock.acquire()
#關鍵部分
...
finally:
lock.release()
另外,所有種類的鎖還支援上下文管理協議(寫起來更簡潔):
with語句自動獲取鎖,並且在控制流離開上下文時自動釋放鎖。
with lock:
#關鍵部分
...
此外,編寫程式碼時一般應該避免同時獲取多個鎖,例如下面就應該儘量避免:
這通知很統一導致應用程式神祕死鎖,儘管與集中策略可以避免出現這種情況(如分層鎖定),但是最好在編寫程式碼時避免這種巢狀鎖。
with lock_A:
#關鍵部分
...
with lock_B:
#B的關鍵部分
...
儘管在Python中可以使用各種鎖和同步原語的組合編寫非常傳統的多執行緒程式,但有一種首推的程式設計方式要優於其他所有程式設計方式:即將多執行緒程式組織為多個獨立任務的集合,這些任務之間通過訊息佇列進行通訊,例如下面要講的queue模組。