婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解Python中的Lock和Rlock

詳解Python中的Lock和Rlock

熱門標(biāo)簽:天津塘沽區(qū)地圖標(biāo)注 如何申請400電話代理 地圖標(biāo)注可以遠(yuǎn)程操作嗎 智能電話機(jī)器人調(diào)研 甘肅高頻外呼系統(tǒng) 滴滴地圖標(biāo)注公司 400電話在線如何申請 杭州房產(chǎn)地圖標(biāo)注 江門智能電話機(jī)器人

線程是進(jìn)程中可以調(diào)度執(zhí)行的實體。而且,它是操作系統(tǒng)中可以執(zhí)行的最小處理單元。簡單地說,一個線程就是一個程序中可以獨立于其他代碼執(zhí)行的指令序列。為了簡單起見,你可以假設(shè)線程只是進(jìn)程的子集!

Locks

鎖是Python中用于同步的最簡單的方式。鎖有兩種狀態(tài):上鎖、釋放鎖。

鎖是線程模塊中的一個類,有兩個主要方法:acquire()和release() 當(dāng)調(diào)用acquire()方法時,它鎖定鎖的執(zhí)行并阻塞鎖的執(zhí)行,直到其他線程調(diào)用release()方法將其設(shè)置為解鎖狀態(tài)。鎖幫助我們有效地訪問程序中的共享資源,以防止數(shù)據(jù)損壞,它遵循互斥,因為一次只能有一個線程訪問特定的資源。

讓我們看看下面的例子來理解鎖的使用:

import threading
 
#創(chuàng)建一個lock對象
lock = threading.Lock()
 
#初始化共享資源
abce = 0
 
def sumOne():
    global abce
 
    #鎖定共享資源
    lock.acquire()
    abce = abce + 1
 
    #釋放共享資源
    lock.release()
 
def sumTwo():
    global abce
 
    #鎖定共享資源
    lock.acquire()
    abce = abce + 2
 
    #釋放共享資源
    lock.release()
 
#調(diào)用函數(shù)
 
sumOne()
sumTwo()
print(abce)

在上面的程序中,lock是一個鎖對象,全局變量abce是一個共享資源,sumOne()和sumTwo()函數(shù)扮作兩個線程,在sumOne()函數(shù)中共享資源abce首先被鎖定,然后增加了1,然后abce被釋放。sumTwo()函數(shù)執(zhí)行類似操作。 兩個函數(shù)sumOne()和sumTwo()不能同時訪問共享資源abce,一次只能一個訪問共享資源。

RLocks

默認(rèn)的lock不能識別lock當(dāng)前被哪個線程持有。如果任何線程正在訪問共享資源,那么試圖訪問共享資源的其他線程將被阻塞,即使鎖定共享資源的線程也是如此。 在這些情況下,可重入鎖(或RLock)用于防止訪問共享資源時出現(xiàn)不必要的阻塞。如果共享資源在RLock中,那么可以安全地再次調(diào)用它。 RLocked資源可以被不同的線程重復(fù)訪問,即使它在被不同的線程調(diào)用時仍然可以正常工作。

讓我們看看下面的例子來理解RLocks的使用:

import threading
 
#創(chuàng)建一個lock對象
lock = threading.Lock()
 
#初始化共享資源
abce = 0
 
#本線程訪問共享資源
lock.acquire()
abce = abce + 1
 
#這個線程訪問共享資源會被阻塞
lock.acquire()
abce = abce + 2
lock.release()
 
print(abce)

在上面的程序中,兩個線程同時嘗試訪問共享資源abce,這里當(dāng)一個線程當(dāng)前正在訪問共享資源abce時,另一個線程將被阻止訪問它。 當(dāng)兩個或多個線程試圖訪問相同的資源時,有效地阻止了彼此訪問該資源,這就是所謂的死鎖,因此上述程序沒有生成任何輸出。

但是,在程序中上述問題可以通過使用RLock來解決。

import threading
 
#創(chuàng)建一個rlock對象
lock = threading.RLock()
 
#初始化共享資源
abce = 0
 
#本線程訪問共享資源
lock.acquire()
abce = abce + 1
 
#這個線程嘗試訪問共享資源
lock.acquire()
abce = abce + 2
lock.release()
 
print(abce)

在這里,沒有阻止程序中的線程訪問共享資源abce。 對于RLock對象鎖的每個acquire(),我們需要調(diào)用release()一次。

從上面提到的眾多程序和解釋中,在Python中一個Lock對象和一個RLock對象有很多區(qū)別:

locks rlocks
lock對象無法再被其他線程獲取,除非持有線程釋放 rlock對象可以被其他線程多次獲取
lock對象可被任何線程釋放 rlock對象只能被持有的線程釋放
lock對象不可以被任何線程擁有 rlock對象可以被多個線程擁有
對一個對象鎖定是很快的 對一個對象加rlock比加lock慢

以上就是詳解Python中的Lock和Rlock的詳細(xì)內(nèi)容,更多關(guān)于Python中Lock和Rlock的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • 對python多線程中Lock()與RLock()鎖詳解
  • Python多線程編程(六):可重入鎖RLock
  • Python多線程同步Lock、RLock、Semaphore、Event實例

標(biāo)簽:重慶 長春 臨汾 河池 廊坊 德宏 東莞 漢中

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Python中的Lock和Rlock》,本文關(guān)鍵詞  詳解,Python,中的,Lock,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解Python中的Lock和Rlock》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解Python中的Lock和Rlock的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 唐河县| 阿坝县| 元氏县| 板桥市| 郧西县| 鹤峰县| 肥西县| 永德县| 岳普湖县| 印江| 堆龙德庆县| 建瓯市| 阳春市| 和政县| 微山县| 筠连县| 娄烦县| 新蔡县| 山东| 海兴县| 肥乡县| 铁岭市| 玛曲县| 南岸区| 阳曲县| 大化| 浦县| 施秉县| 西华县| 柏乡县| 高州市| 玉环县| 武定县| 长春市| 沅江市| 界首市| 开封县| 石城县| 启东市| 睢宁县| 龙南县|