日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

瀏覽:39日期:2022-06-19 15:51:27
目錄控制資源訪問判斷是否有另一個(gè)線程請(qǐng)求鎖with lock同步線程Condition屏障(barrier)有限資源的并發(fā)訪問隱藏資源控制資源訪問

前文提到threading庫(kù)在多線程時(shí),對(duì)同一資源的訪問容易導(dǎo)致破壞與丟失數(shù)據(jù)。為了保證安全的訪問一個(gè)資源對(duì)象,我們需要?jiǎng)?chuàng)建鎖。

示例如下:

import threadingimport timeclass AddThread(): def __init__(self, start=0):self.lock = threading.Lock()self.value = start def increment(self):print('Wait Lock')self.lock.acquire()try: print('Acquire Lock') self.value += 1 print(self.value)finally: self.lock.release()def worker(a): time.sleep(1) a.increment()addThread = AddThread()for i in range(3): t = threading.Thread(target=worker, args=(addThread,)) t.start()

運(yùn)行之后,效果如下:

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

acquire()會(huì)通過鎖進(jìn)行阻塞其他線程執(zhí)行中間段,release()釋放鎖,可以看到,基本都是獲得鎖之后才執(zhí)行。避免了多個(gè)線程同時(shí)改變其資源對(duì)象,不會(huì)造成混亂。

判斷是否有另一個(gè)線程請(qǐng)求鎖

要確定是否有另一個(gè)線程請(qǐng)求鎖而不影響當(dāng)前的線程,可以設(shè)置acquire()的參數(shù)blocking=False。

示例如下:

import threadingimport timedef worker2(lock): print('worker2 Wait Lock') while True:lock.acquire()try: print('Holding') time.sleep(0.5)finally: print('not Holding') lock.release()time.sleep(0.5)def worker1(lock): print('worker1 Wait Lock') num_acquire = 0 value = 0 while num_acquire < 3:time.sleep(0.5)have_it = lock.acquire(blocking=False)try: value += 1 print(value) print('Acquire Lock') if have_it:num_acquire += 1finally: print('release Lock') if have_it:lock.release()lock = threading.Lock()word2Thread = threading.Thread( target=worker2, name=’work2’, args=(lock,))word2Thread.start()word1Thread = threading.Thread( target=worker1, name=’work1’, args=(lock,))word1Thread.start()

運(yùn)行之后,效果如下:

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

這里,我們需要迭代很多次,work1才能獲取3次鎖。但是嘗試了很8次。

with lock

前文,我們通過lock.acquire()與lock.release()實(shí)現(xiàn)了鎖的獲取與釋放,但其實(shí)我們Python還給我們提供了一個(gè)更簡(jiǎn)單的語(yǔ)法,通過with lock來(lái)獲取與釋放鎖。

示例如下:

import threadingimport timeclass AddThread(): def __init__(self, start=0):self.lock = threading.Lock()self.value = start def increment(self):print('Wait Lock')with self.lock: print('lock acquire') self.value += 1 print(self.value)print('lock release')def worker(a): time.sleep(1) a.increment()addThread = AddThread()for i in range(3): t = threading.Thread(target=worker, args=(addThread,)) t.start()

這里,我們只是將最上面的例子改變了一下。效果如下:

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

需要注意的是,正常的Lock對(duì)象不能請(qǐng)求多次,即使是由同一個(gè)線程請(qǐng)求也不例外。如果同一個(gè)調(diào)用鏈中的多個(gè)函數(shù)訪問一個(gè)鎖,則會(huì)發(fā)生意外。如果期望在同一個(gè)線程的不同代碼需要重新獲得鎖,那么這種情況下使用RLock。

同步線程Condition

在實(shí)際的操作中,我們還可以使用Condition對(duì)象來(lái)同步線程。由于Condition使用了一個(gè)Lock,所以它可以綁定到一個(gè)共享資源,允許多個(gè)線程等待資源的更新。

示例如下:

import threadingimport timedef consumer(cond): print('waitCon') with cond:cond.wait()print(’獲取更新的資源’)def producer(cond): print('worker') with cond:print(’更新資源’)cond.notifyAll()cond = threading.Condition()t1 = threading.Thread(name=’t1’, target=consumer, args=(cond,))t2 = threading.Thread(name=’t2’, target=consumer, args=(cond,))t3 = threading.Thread(name=’t3’, target=producer, args=(cond,))t1.start()time.sleep(0.2)t2.start()time.sleep(0.2)t3.start()

運(yùn)行之后,效果如下:

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

這里,我們通過producer線程處理完成之后調(diào)用notifyAll(),consumer等線程等到了它的更新,可以類比為觀察者模式。這里是,當(dāng)一個(gè)線程用完資源之后時(shí),則會(huì)自動(dòng)通知依賴它的所有線程。

屏障(barrier)

屏障是另一種線程的同步機(jī)制。barrier會(huì)建立一個(gè)控制點(diǎn),所有參與的線程會(huì)在這里阻塞,直到所有這些參與方都到達(dá)這一點(diǎn)。采用這種方法,線程可以單獨(dú)啟動(dòng)然后暫停,直到所有線程都準(zhǔn)備好了才可以繼續(xù)。

示例如下:

import threadingimport timedef worker(barrier): print(threading.current_thread().getName(), 'worker') worker_id = barrier.wait() print(threading.current_thread().getName(), worker_id)threads = []barrier = threading.Barrier(3)for i in range(3): threads.append(threading.Thread( name='t' + str(i), target=worker, args=(barrier,)) )for t in threads: print(t.name, ’starting’) t.start() time.sleep(0.1)for t in threads: t.join()

運(yùn)行之后,效果如下:

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

從控制臺(tái)的輸出會(huì)發(fā)發(fā)現(xiàn),barrier.wait()會(huì)阻塞線程,直到所有線程被創(chuàng)建后,才同時(shí)釋放越過這個(gè)控制點(diǎn)繼續(xù)執(zhí)行。wait()的返回值指示了釋放的參與線程數(shù),可以用來(lái)限制一些線程做清理資源等動(dòng)作。

當(dāng)然屏障Barrier還有一個(gè)abort()方法,該方法可以使所有等待線程接收一個(gè)BroKenBarrierError。如果線程在wait()上被阻塞而停止處理,會(huì)產(chǎn)生這個(gè)異常,通過except可以完成清理工作。

有限資源的并發(fā)訪問

除了多線程可能訪問同一個(gè)資源之外,有時(shí)候?yàn)榱诵阅埽覀円矔?huì)限制多線程訪問同一個(gè)資源的數(shù)量。例如,線程池支持同時(shí)連接,但數(shù)據(jù)可能是固定的,或者一個(gè)網(wǎng)絡(luò)APP提供的并發(fā)下載數(shù)支持固定數(shù)目。這些連接就可以使用Semaphore來(lái)管理。

示例如下:

import threadingimport timeclass WorkerThread(threading.Thread): def __init__(self):super(WorkerThread, self).__init__()self.lock = threading.Lock()self.value = 0 def increment(self):with self.lock: self.value += 1 print(self.value)def worker(s, pool): with s:print(threading.current_thread().getName())pool.increment()time.sleep(1)pool.increment()pool = WorkerThread()s = threading.Semaphore(2)for i in range(5): t = threading.Thread(name='t' + str(i),target=worker,args=(s, pool,) ) t.start()

運(yùn)行之后,效果如下:

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

從圖片雖然能看所有輸出,但無(wú)法看到其停頓的事件。讀者自己運(yùn)行會(huì)發(fā)現(xiàn),每次頂多只有兩個(gè)線程在工作,是因?yàn)槲覀冊(cè)O(shè)置了threading.Semaphore(2)。

隱藏資源

在實(shí)際的項(xiàng)目中,有些資源需要鎖定以便于多個(gè)線程使用,而另外一些資源則需要保護(hù),以使它們對(duì)并非使這些資源的所有者的線程隱藏。

local()函數(shù)會(huì)創(chuàng)建一個(gè)對(duì)象,它能夠隱藏值,使其在不同的線程中無(wú)法被看到。示例如下:

import threadingimport randomdef show_data(data): try:result = data.value except AttributeError:print(threading.current_thread().getName(), 'No value') else:print(threading.current_thread().getName(), 'value=', result)def worker(data): show_data(data) data.value = random.randint(1, 100) show_data(data)local_data = threading.local()show_data(local_data)local_data.value = 1000show_data(local_data)for i in range(2): t = threading.Thread(name='t' + str(i),target=worker,args=(local_data,) ) t.start()

運(yùn)行之后,效果如下:

Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖

這里local_data.value對(duì)所有線程都不可見,除非在某個(gè)線程中設(shè)置了這個(gè)屬性,這個(gè)線程才能看到它。

到此這篇關(guān)于Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖的文章就介紹到這了,更多相關(guān)Python 線程鎖與釋放鎖內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
中文一区一区三区免费在线观| 日韩免费视频| 久久精品1区| 日本精品在线中文字幕| 午夜精品成人av| 色爱综合网欧美| 在线观看精品| 在线国产一区二区| 99国产一区| 亚洲精品黄色| 日本免费在线视频不卡一不卡二| 日韩va欧美va亚洲va久久| 欧美日韩1区| 久久影院资源站| 97精品视频在线看| 在线观看免费一区二区| 亚洲欧洲日韩精品在线| 亚洲欧洲美洲国产香蕉| 国产乱子精品一区二区在线观看 | 亚洲一区二区av| 日韩国产高清在线| 久久免费精品| 99精品在线观看| 免费在线欧美视频| 国产精品一区二区免费福利视频 | 国产精品一区二区三区美女| 久久精品午夜| 色爱av综合网| 99视频一区| 日韩国产欧美一区二区三区| 麻豆一区二区三区| 欧美肉体xxxx裸体137大胆| 亚洲永久字幕| 欧美天堂在线| 国产色播av在线| 91久久中文| 久久国产精品免费精品3p| 中文在线中文资源| 一区二区91| 97精品中文字幕| 免费在线观看成人| 麻豆精品少妇| 91久久中文| 欧美一区91| 久久久精品久久久久久96| 亚洲人亚洲人色久| 在线看片福利| 午夜亚洲福利| 97国产精品| 蜜桃久久精品一区二区| 久久一区精品| 国产麻豆综合| 国产一区二区三区精品在线观看 | 免费在线看一区| 精品国产一区二区三区性色av| 国产一区二区三区自拍| 日韩1区2区日韩1区2区| 色老板在线视频一区二区| 日韩三级久久| 夜鲁夜鲁夜鲁视频在线播放| 日韩视频一二区| 91精品蜜臀一区二区三区在线| 日韩动漫一区| 亚洲激情婷婷| 激情黄产视频在线免费观看| 四虎国产精品免费观看| 久久只有精品| 香蕉久久夜色精品国产| 日韩精品免费一区二区夜夜嗨| 精品久久91| 蜜臀国产一区二区三区在线播放| 麻豆网站免费在线观看| 国产亚洲高清一区| 亚洲一区二区三区在线免费| 欧美福利在线| 成人看片网站| 国产aⅴ精品一区二区四区| 久久精品五月| 成人午夜网址| 日本不卡的三区四区五区| 欧美日韩国产高清电影| 国产日韩1区| 亚洲免费资源| 中文亚洲免费| 婷婷综合一区| 国产免费av国片精品草莓男男 | 91大神在线观看线路一区| 亚洲女同一区| 亚洲伊人av| 免费日韩成人| 91成人在线精品视频| 日韩在线一区二区| 亚洲电影在线一区二区三区| 日韩一区亚洲二区| 精品视频91| 国产精品tv| 日韩欧美高清一区二区三区| 亚洲自啪免费| 国产综合精品| 国产v日韩v欧美v| 国产一区三区在线播放| 麻豆精品久久| 久久99久久人婷婷精品综合| 国产区精品区| 日本伊人久久| 日本一不卡视频| 日韩一区二区三区精品视频第3页| 久久亚洲精品伦理| 99国产精品久久久久久久| 婷婷综合激情| 激情欧美一区二区三区| 国产综合色产| 午夜日韩福利| 午夜在线一区二区| 尤物在线精品| 日韩视频免费| 日韩一区精品视频| 中文字幕日本一区二区| 中文不卡在线| 日本va欧美va精品| 人人精品久久| 国产精品美女久久久久久不卡| 欧美天堂在线| 美女视频网站久久| 精品99在线| 麻豆成全视频免费观看在线看| 精品色999| 欧美aa国产视频| 午夜在线视频观看日韩17c| 国产99久久| 麻豆91精品| 99久久激情| 国产乱码午夜在线视频| 免费在线欧美黄色| 鲁大师影院一区二区三区| 国产精品福利在线观看播放| 亚洲丝袜美腿一区| 国产精品xx| 国产中文在线播放| 日本色综合中文字幕| 国产精成人品2018| 亚洲免费影院| 麻豆免费精品视频| 先锋影音久久久| 久久av日韩| 日韩视频精品在线观看| 在线亚洲观看| 久久精品电影| 99免费精品| 中文字幕亚洲精品乱码| 亚洲精品国产偷自在线观看| 久热re这里精品视频在线6| 日韩在线视频一区二区三区| 久久99影视| 在线日韩欧美| 天海翼精品一区二区三区| 老司机精品视频网| 999久久久亚洲| 日韩亚洲精品在线观看| 欧美日韩亚洲一区三区| 日韩毛片视频| 亚洲久草在线| 久久69成人| 亚洲资源在线| 亚洲精品系列| 婷婷久久一区| 成人台湾亚洲精品一区二区| 青青伊人久久| 国产精品入口久久| 丝袜美腿高跟呻吟高潮一区| 欧美国产极品| 一区二区亚洲视频| 婷婷成人在线| 成人精品国产亚洲| 亚洲欧美日本国产专区一区| 精品91福利视频| 亚洲精品一区二区妖精| 免费成人性网站| 桃色一区二区| 男人的天堂久久精品| 国产精品porn| 亚洲高清不卡| 欧美一区成人| 999精品一区| 欧美日一区二区三区在线观看国产免 | 日韩av在线中文字幕| 久久中文亚洲字幕| 青草国产精品| 午夜精品网站| 精品国产欧美日韩| 亚洲人妖在线| 999久久久免费精品国产| 国产亚洲精aa在线看| 五月综合激情| 欧美激情国产在线| 日韩av一区二区三区| 91九色精品| a天堂资源在线| 国产日产精品_国产精品毛片 | 三级在线观看一区二区|