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

您的位置:首頁技術文章
文章詳情頁

Python中threading庫實現線程鎖與釋放鎖

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

前文提到threading庫在多線程時,對同一資源的訪問容易導致破壞與丟失數據。為了保證安全的訪問一個資源對象,我們需要創建鎖。

示例如下:

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()

運行之后,效果如下:

Python中threading庫實現線程鎖與釋放鎖

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

判斷是否有另一個線程請求鎖

要確定是否有另一個線程請求鎖而不影響當前的線程,可以設置acquire()的參數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()

運行之后,效果如下:

Python中threading庫實現線程鎖與釋放鎖

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

with lock

前文,我們通過lock.acquire()與lock.release()實現了鎖的獲取與釋放,但其實我們Python還給我們提供了一個更簡單的語法,通過with lock來獲取與釋放鎖。

示例如下:

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庫實現線程鎖與釋放鎖

需要注意的是,正常的Lock對象不能請求多次,即使是由同一個線程請求也不例外。如果同一個調用鏈中的多個函數訪問一個鎖,則會發生意外。如果期望在同一個線程的不同代碼需要重新獲得鎖,那么這種情況下使用RLock。

同步線程Condition

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

示例如下:

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()

運行之后,效果如下:

Python中threading庫實現線程鎖與釋放鎖

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

屏障(barrier)

屏障是另一種線程的同步機制。barrier會建立一個控制點,所有參與的線程會在這里阻塞,直到所有這些參與方都到達這一點。采用這種方法,線程可以單獨啟動然后暫停,直到所有線程都準備好了才可以繼續。

示例如下:

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()

運行之后,效果如下:

Python中threading庫實現線程鎖與釋放鎖

從控制臺的輸出會發發現,barrier.wait()會阻塞線程,直到所有線程被創建后,才同時釋放越過這個控制點繼續執行。wait()的返回值指示了釋放的參與線程數,可以用來限制一些線程做清理資源等動作。

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

有限資源的并發訪問

除了多線程可能訪問同一個資源之外,有時候為了性能,我們也會限制多線程訪問同一個資源的數量。例如,線程池支持同時連接,但數據可能是固定的,或者一個網絡APP提供的并發下載數支持固定數目。這些連接就可以使用Semaphore來管理。

示例如下:

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()

運行之后,效果如下:

Python中threading庫實現線程鎖與釋放鎖

從圖片雖然能看所有輸出,但無法看到其停頓的事件。讀者自己運行會發現,每次頂多只有兩個線程在工作,是因為我們設置了threading.Semaphore(2)。

隱藏資源

在實際的項目中,有些資源需要鎖定以便于多個線程使用,而另外一些資源則需要保護,以使它們對并非使這些資源的所有者的線程隱藏。

local()函數會創建一個對象,它能夠隱藏值,使其在不同的線程中無法被看到。示例如下:

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()

運行之后,效果如下:

Python中threading庫實現線程鎖與釋放鎖

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

到此這篇關于Python中threading庫實現線程鎖與釋放鎖的文章就介紹到這了,更多相關Python 線程鎖與釋放鎖內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
91精品国产乱码久久久久久久| 天堂成人免费av电影一区| 亚洲资源网站| 最新国产拍偷乱拍精品| 免费观看久久av| 91久久黄色| 首页国产欧美久久| 日韩午夜视频在线| 国产精品网在线观看| 精品色999| 国产成人精品亚洲线观看| 精品视频久久| 欧美成人a交片免费看| 久久国产影院| 欧美精品激情| 亚洲精品国产日韩| 国产精品一区二区三区av麻| 老司机精品视频在线播放| 国产精品一区二区精品视频观看| 美腿丝袜在线亚洲一区| 狠狠久久伊人中文字幕| 新版的欧美在线视频| 在线日韩电影| 伊人国产精品| 国产欧美日韩精品一区二区三区| 美女高潮久久久| 亚洲综合电影| 在线精品视频在线观看高清| 性色av一区二区怡红| 天堂精品久久久久| 麻豆高清免费国产一区| 久久精品国产www456c0m| 首页国产欧美日韩丝袜| 日本精品在线播放| 久久久久久婷| 国产精品试看| 国产视频一区二| av最新在线| 日韩精品一二三| 麻豆精品少妇| 91久久中文| 国产精品久久久久久久久久白浆 | 日本aⅴ免费视频一区二区三区| 欧美日韩91| 亚洲欧洲高清| 视频精品一区二区| 国产高清亚洲| 欧美成人综合| 国产日韩视频在线| 久久国产视频网| 999视频精品| 天海翼亚洲一区二区三区| 麻豆精品视频在线| 亚洲在线观看| 美女国产一区二区三区| 亚洲综合三区| 麻豆久久一区二区| 免费在线成人网| 国产精品伦理久久久久久| 蜜桃av一区二区| 色爱综合网欧美| 亚洲专区视频| 日韩一区电影| 欧美一区=区三区| 亚洲韩日在线| 国产激情久久| 在线观看视频免费一区二区三区| 久久99性xxx老妇胖精品| 亚洲大全视频| 狂野欧美性猛交xxxx| 一二三区精品| 亚洲高清毛片| bbw在线视频| 国产精品亚洲欧美一级在线| 中文日韩在线| 理论片午夜视频在线观看| 日韩三级精品| 亚洲国产成人精品女人| 欧美国产小视频| 国产欧美日韩综合一区在线播放| 亚洲欧洲一区| 亚洲伦乱视频| 国产欧美日韩| 尤物精品在线| 五月激情久久| 国产一区二区久久久久| 日本特黄久久久高潮| 最新国产拍偷乱拍精品| 久久久久91| 亚洲一区网站| 激情久久五月| 色爱综合网欧美| 免费一级欧美在线观看视频| 亚洲精品九九| 一区二区三区国产盗摄| 不卡av一区二区| 日韩av首页| 精品视频亚洲| 欧美激情日韩| 国产探花一区二区| 日本va欧美va欧美va精品| 日韩一区欧美二区| 怡红院精品视频在线观看极品| 韩国三级一区| 91看片一区| 日韩网站中文字幕| 免费在线小视频| 日韩国产欧美一区二区| 精品国产aⅴ| 精品免费视频| 免费在线观看一区| 国产精品极品| 国产精品亚洲产品| 久久国产三级精品| 国产精一区二区| 国产精品中文| 国产精品第十页| 国产精品欧美日韩一区| 久久99久久久精品欧美| 久久99青青| 精品久久久久中文字幕小说| 91嫩草精品| 久久国产免费看| 国产精一区二区| 久久精品免视看国产成人| 美女视频免费精品| 精品三级在线| 国产一区二区三区四区五区| 麻豆91在线播放| 日韩1区2区| 色天使综合视频| 国产色综合网| 亚洲精品四区| 国产亚洲久久| 精品欠久久久中文字幕加勒比| 水蜜桃久久夜色精品一区| 日韩精品午夜| 久久国产精品99国产| 日韩欧美另类中文字幕| 国产精品久久久久毛片大屁完整版 | 日韩国产一区二区| 日韩电影免费网站| 蜜桃视频欧美| 免费观看在线综合色| 日本视频中文字幕一区二区三区| 国产精品九九| 91一区二区三区四区| 欧美日韩在线观看视频小说| 尤物在线精品| 亚洲精品欧美| 久久精品国产成人一区二区三区| 91亚洲人成网污www| 激情婷婷久久| 亚洲开心激情| 欧美a在线观看| 成人亚洲一区| 一区三区视频| 久久精品99久久久| 日韩黄色大片| 男女男精品网站| 国产精品高潮呻吟久久久久| 在线观看精品| 亚洲综合中文| 欧美激情福利| 国产真实久久| 亚洲精品激情| 水蜜桃精品av一区二区| 国产免费成人| 国产极品久久久久久久久波多结野| 日韩欧美另类一区二区| 午夜宅男久久久| 国产精品观看| 自由日本语亚洲人高潮| 亚洲精品九九| 中文字幕在线视频网站| 首页亚洲欧美制服丝腿| 久久亚洲黄色| 亚洲一区二区成人| 麻豆精品新av中文字幕| 亚洲精品一区二区妖精| 国产精品国码视频| 欧美日韩国产探花| 欧美伊人久久| 国产在线不卡| 久久精品资源| 亚洲一区二区毛片| 国内精品伊人| 蜜桃视频第一区免费观看| 国产一区国产二区国产三区| 六月婷婷一区| 久久久久久夜| 88久久精品| 日韩午夜精品| 高清av一区| 亚洲aⅴ网站| 韩日一区二区三区| 久久男人av| 日韩成人一级| 亚洲女人av| 丝袜美腿一区|