您好,登錄后才能下訂單哦!
這篇文章主要講解了“在Python定時器中Lock的實際應(yīng)用方式介紹”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“在Python定時器中Lock的實際應(yīng)用方式介紹”吧!
在Python定時器中Lock的實際應(yīng)用
Lock/RLock 和 C# lock 關(guān)鍵字差不多意思。不同的是,Lock/RLock 只需 "鎖定" 自己,而 C# lock 還得另外找個引用類型對象。Lock 有個問題就是同一個線程內(nèi)部也不能多次 "鎖定",否則會死鎖。RLock 沒有這個問題,它會處理 "owning thread" 和 "recursion level" 狀態(tài),對于同一線程的多次請求鎖行為,只累加計數(shù)器。
每次調(diào)用 release() 將遞減該計數(shù)器,直到 0 時釋放鎖,因此記住 acquire() 和 release() 要成對出現(xiàn)。直接用 RLock,忘了 Lock 吧。
非鎖定版本:
def test(): for i in range(3): print currentThread().name, i sleep(1) for i in range(2): Thread(target = test).start()
輸出:
$ ./main.py Thread-1 0 Thread-2 0 Thread-1 1 Thread-2 1 Thread-1 2 Thread-2 2
鎖定版本:
lock = RLock() def test(): lock.acquire() try: for i in range(3): print currentThread().name, i sleep(1) finally: lock.release() for i in range(2): Thread(target = test).start()
輸出:
$ ./main.py Thread-1 0 Thread-1 1 Thread-1 2 Thread-2 0 Thread-2 1 Thread-2 2
RLock 實現(xiàn)了 Context Management Protocol,會自動調(diào)用 acquire() 和 release() 函數(shù),因此直接用 with/as 來實現(xiàn) C# "lock(o) { ... }"。
lock = RLock() def test(): with lock: for i in range(3): print currentThread().name, i sleep(1) for i in range(2): Thread(target = test).start()
感謝各位的閱讀,以上就是“在Python定時器中Lock的實際應(yīng)用方式介紹”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對在Python定時器中Lock的實際應(yīng)用方式介紹這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。