您好,登錄后才能下訂單哦!
使用諸如Lock、RLock、Semphore之類的鎖原語時,必須多加小心,鎖的錯誤使用很容易導致死鎖或相互競爭。依賴鎖的代碼應該保證當出現異常時可以正常的釋放鎖。
典型代碼如下:
try: lock.acquire() #關鍵部分 ... finally: lock.release()
另外,所有種類的鎖還支持上下文管理協議(寫起來更簡潔):
with語句自動獲取鎖,并且在控制流離開上下文時自動釋放鎖。
with lock: #關鍵部分 ...
此外,編寫代碼時一般應該避免同時獲取多個鎖,例如下面就應該盡量避免:
這通知很統一導致應用程序神秘死鎖,盡管與集中策略可以避免出現這種情況(如分層鎖定),但是最好在編寫代碼時避免這種嵌套鎖。
with lock_A: #關鍵部分 ... with lock_B: #B的關鍵部分 ...
盡管在Python中可以使用各種鎖和同步原語的組合編寫非常傳統的多線程程序,但有一種首推的編程方式要優于其他所有編程方式:即將多線程程序組織為多個獨立任務的集合,這些任務之間通過消息隊列進行通信,例如下面要講的queue模塊。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。