簡體   English   中英

Python二進制信號量VS鎖

[英]Python binary semaphore VS lock

我們正在多線程python環境中工作,需要對一段代碼進行互斥,例如:

lock = threading.Lock()
with lock:
    # get data from shared storage
    # process
    # put back to shared storage

目前在我看來,二進制信號量threading.Semaphore()和lock threading.Lock()將同樣為此服務。 如果我從鎖定切換到二進制信號量,反之亦然,是否存在一些陷阱或增益?

注意:在greenthreads內運行的代碼(如果情況發生變化)

可以說Semaphore是Lock的高級版本。 信號量有一個自定義數字來控制多個線程來訪問資源。 但是Lock只有一個。

threading.Semaphore()在內部使用threading.Lock()對象作為監視器。 當調用Semaphore.acquire() ,信號量對象在其Lock對象上調用acquire,減小其值,並釋放鎖。

由此可見,二進制信號量實際上只是一個Lock的包裝器。 我想不出兩者之間的任何功能差異,除了使用Semaphore你可以傳遞可選的verbose = True參數用於調試目的,並且可以選擇用blocking = False調用acquire。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM