欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python?threading中l(wèi)ock的使用詳解

 更新時(shí)間:2022年11月22日 11:19:30   作者:鍋爐房劉大爺  
Lock類(lèi)是threading中用于鎖定當(dāng)前線程的鎖定類(lèi),本文給大家介紹了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í)刷新(挖坑和填坑)

    這篇文章主要介紹了詳解pyqt5的UI中嵌入matplotlib圖形并實(shí)時(shí)刷新(挖坑和填坑),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • python3.4+pycharm 環(huán)境安裝及使用方法

    python3.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特性

    關(guān)于你不想知道的所有Python3 unicode特性

    我的讀者知道我是一個(gè)喜歡痛罵Python3 unicode的人。這次也不例外。我將會(huì)告訴你用unicode有多痛苦和為什么我不能閉嘴。我花了兩周時(shí)間研究Python3,我需要發(fā)泄我的失望。在這些責(zé)罵中,仍然有有用的信息,因?yàn)樗涛覀內(nèi)绾蝸?lái)處理Python3。如果沒(méi)有被我煩到,就讀一讀吧
    2014-11-11
  • Python編程中歸并排序算法的實(shí)現(xiàn)步驟詳解

    Python編程中歸并排序算法的實(shí)現(xiàn)步驟詳解

    這篇文章主要介紹了Python編程中歸并排序算法的實(shí)現(xiàn)步驟詳解,歸并排序的平均時(shí)間復(fù)雜度為(n\log n),需要的朋友可以參考下
    2016-05-05
  • python中l(wèi)strip()截掉字符的實(shí)例講解

    python中l(wèi)strip()截掉字符的實(shí)例講解

    在本篇文章里小編給大家整理的是一篇關(guān)于python中l(wèi)strip()截掉字符的實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2021-05-05
  • 一文帶你解密Python迭代器的實(shí)現(xiàn)原理

    一文帶你解密Python迭代器的實(shí)現(xiàn)原理

    這篇文章主要為大家詳細(xì)介紹了Python中迭代器的實(shí)現(xiàn)原理,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定的幫助,需要的可以參考一下
    2022-12-12
  • Python 使用類(lèi)寫(xiě)裝飾器的小技巧

    Python 使用類(lèi)寫(xiě)裝飾器的小技巧

    裝飾器是一個(gè)返回函數(shù)的函數(shù)。寫(xiě)一個(gè)裝飾器,除了最常見(jiàn)的在函數(shù)中定義函數(shù)以外,Python還允許使用類(lèi)來(lái)定義一個(gè)裝飾器。這篇文章給大家分享Python 使用類(lèi)寫(xiě)裝飾器的小技巧,一起看看吧
    2018-09-09
  • python遍歷一個(gè)目錄,輸出所有的文件名的實(shí)例

    python遍歷一個(gè)目錄,輸出所有的文件名的實(shí)例

    下面小編就為大家分享一篇python遍歷一個(gè)目錄,輸出所有的文件名的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • python爬蟲(chóng)之教你如何爬取地理數(shù)據(jù)

    python爬蟲(chóng)之教你如何爬取地理數(shù)據(jù)

    這篇文章主要介紹了python爬蟲(chóng)之教你如何爬取地理數(shù)據(jù),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們有很好的幫助,需要的朋友可以參考下
    2021-04-04
  • python輕量級(jí)orm框架 peewee常用功能速查詳情

    python輕量級(jí)orm框架 peewee常用功能速查詳情

    Peewee是一種簡(jiǎn)單而小的ORM。它有很少的(但富有表現(xiàn)力的)概念,使它易于學(xué)習(xí)和直觀的使用,感興趣的朋友可以參考下面文章的具體內(nèi)容
    2021-09-09

最新評(píng)論