Python?threading中l(wèi)ock的使用詳解
在多線程中使用lock可以讓多個(gè)線程在共享資源的時(shí)候不會(huì)“亂”,例如,創(chuàng)建多個(gè)線程,每個(gè)線程都往空列表l中添加一個(gè)數(shù)字并打印當(dāng)前的列表l,如果不加鎖,就可能會(huì)這樣:
# encoding=utf8 import threading import time lock = threading.Lock() l = [] def test1(n): lock.acquire() l.append(n) print l lock.release() def test(n): l.append(n) print l def main(): for i in xrange(0, 10): th = threading.Thread(target=test, args=(i, )) th.start() if __name__ == '__main__': main()
運(yùn)行結(jié)果:
[0]
[0, 1]
[0, 1, 2]
[0, 1, 2, 3][
0, 1, 2, 3, 4]
[0, 1, 2, 3, 4, 5]
[0, 1, 2, 3, 4[, 05, , 16, , 27, ]3
, 4, 5, 6[, 07, , 18, ]2
, 3, 4, [50, , 61, , 72, , 83, , 94],
5, 6, 7, 8, 9]
因?yàn)槊總€(gè)線程都在同時(shí)往l中添加一個(gè)數(shù)字(當(dāng)前每個(gè)線程運(yùn)行的是test函數(shù)),然后又可能在同時(shí)打印l,所以最后的結(jié)果看起來(lái)會(huì)有些“混亂”。
下面讓每個(gè)線程調(diào)用“test1”函數(shù),看看結(jié)果如何:
[0]
[0, 1]
[0, 1, 2]
[0, 1, 2, 3]
[0, 1, 2, 3, 4]
[0, 1, 2, 3, 4, 5]
[0, 1, 2, 3, 4, 5, 6]
[0, 1, 2, 3, 4, 5, 6, 7]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
現(xiàn)在看起來(lái)就好多了,因?yàn)閠est1中每次像l中添加數(shù)字并打印之前,都先加了一把“鎖”,這樣就可以保證每次只有一個(gè)線程可以往l中添加數(shù)字,而不是同時(shí)往l里添加數(shù)字。
通過(guò)上面的結(jié)果比較可以知道,當(dāng)多線程中需要“獨(dú)占資源”的時(shí)候,要使用鎖來(lái)控制,防止多個(gè)線程同時(shí)占用資源而出現(xiàn)其他異常。
使用鎖的時(shí)候就調(diào)用acquire()方法,以此告訴其他線程,我正在占用該資源,你們要等會(huì);待使用資源后需要釋放資源的時(shí)候就調(diào)用release()方法,告訴其他線程,我已經(jīng)完成使用該資源了,其他人可以過(guò)來(lái)使用了。
python threading Lock
這篇文章主要是通過(guò)代碼說(shuō)明:
threading.Lock()
不影響multiprocessing
- .
threading.Lock()
影響threading
.
代碼如下:
import threading import time from multiprocessing import Pool _lock = threading.Lock() def small_func(value): """ 添加線程鎖 :param value: :return: """ print(value) with _lock: time.sleep(5) return value def no_small_func(value): """ 沒(méi)有線程鎖 :param value: :return: """ print(value) # with _lock: time.sleep(5) return value def main(): """ multiprocessing 是基于進(jìn)程的,因此線程鎖對(duì)其不影響, :return: """ st = time.time() p = Pool(processes=4) value = p.map(func=small_func, iterable=range(4)) et = time.time() print(f"all use time: {et - st}") print(value) def main2(): """ threading 受到 線程鎖 影響 :return: """ st = time.time() thread_list = [] for temp_value in range(4): t = threading.Thread(target=small_func, args=(temp_value,)) t.start() thread_list.append(t) for i in thread_list: i.join() et = time.time() print(f"all use time: {et - st}") # print(value) def main3(): st = time.time() thread_list = [] res = [] for temp_value in range(4): # 不加線程鎖就行了 t = threading.Thread(target=no_small_func, args=(temp_value,)) t.start() thread_list.append(t) for i in thread_list: v = i.join() res.append(v) et = time.time() print(f"all use time: {et - st}") print(res) if __name__ == '__main__': # main() # main2() main3()
到此這篇關(guān)于Python threading中l(wèi)ock的使用的文章就介紹到這了,更多相關(guān)Python threading lock使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解pyqt5的UI中嵌入matplotlib圖形并實(shí)時(shí)刷新(挖坑和填坑)
這篇文章主要介紹了詳解pyqt5的UI中嵌入matplotlib圖形并實(shí)時(shí)刷新(挖坑和填坑),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08python3.4+pycharm 環(huán)境安裝及使用方法
這篇文章主要介紹了python3.4+pycharm 環(huán)境安裝及使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06關(guān)于你不想知道的所有Python3 unicode特性
我的讀者知道我是一個(gè)喜歡痛罵Python3 unicode的人。這次也不例外。我將會(huì)告訴你用unicode有多痛苦和為什么我不能閉嘴。我花了兩周時(shí)間研究Python3,我需要發(fā)泄我的失望。在這些責(zé)罵中,仍然有有用的信息,因?yàn)樗涛覀內(nèi)绾蝸?lái)處理Python3。如果沒(méi)有被我煩到,就讀一讀吧2014-11-11Python編程中歸并排序算法的實(shí)現(xiàn)步驟詳解
這篇文章主要介紹了Python編程中歸并排序算法的實(shí)現(xiàn)步驟詳解,歸并排序的平均時(shí)間復(fù)雜度為(n\log n),需要的朋友可以參考下2016-05-05python中l(wèi)strip()截掉字符的實(shí)例講解
在本篇文章里小編給大家整理的是一篇關(guān)于python中l(wèi)strip()截掉字符的實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2021-05-05一文帶你解密Python迭代器的實(shí)現(xiàn)原理
這篇文章主要為大家詳細(xì)介紹了Python中迭代器的實(shí)現(xiàn)原理,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定的幫助,需要的可以參考一下2022-12-12python遍歷一個(gè)目錄,輸出所有的文件名的實(shí)例
下面小編就為大家分享一篇python遍歷一個(gè)目錄,輸出所有的文件名的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04python爬蟲(chóng)之教你如何爬取地理數(shù)據(jù)
這篇文章主要介紹了python爬蟲(chóng)之教你如何爬取地理數(shù)據(jù),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們有很好的幫助,需要的朋友可以參考下2021-04-04python輕量級(jí)orm框架 peewee常用功能速查詳情
Peewee是一種簡(jiǎn)單而小的ORM。它有很少的(但富有表現(xiàn)力的)概念,使它易于學(xué)習(xí)和直觀的使用,感興趣的朋友可以參考下面文章的具體內(nèi)容2021-09-09