Python執行緒專題8:使用鎖的注意事項

Mark發表於2019-02-16

上一篇文章: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模組。

相關文章