日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Python多線程編程(六):可重入鎖RLock

系統 1706 0

考慮這種情況:如果一個線程遇到鎖嵌套的情況該怎么辦,這個嵌套是指當我一個線程在獲取臨界資源時,又需要再次獲取。

根據這種情況,代碼如下:

復制代碼 代碼如下:

'''
Created on 2012-9-8
?
@author: walfred
@module: thread.ThreadTest6
'''?
?
import threading?
import time?
?
counter = 0?
mutex = threading.Lock()?
?
class MyThread(threading.Thread):?
??? def __init__(self):?
??????? threading.Thread.__init__(self)?
?
??? def run(self):?
??????? global counter, mutex?
??????? time.sleep(1);?
??????? if mutex.acquire():?
??????????? counter += 1?
??????????? print "I am %s, set counter:%s" % (self.name, counter)?
??????????? if mutex.acquire():?
??????????????? counter += 1?
??????????????? print "I am %s, set counter:%s" % (self.name, counter)?
??????????????? mutex.release()?
??????????? mutex.release()?
?
if __name__ == "__main__":?
??? for i in range(0, 200):?
??????? my_thread = MyThread()?
??????? my_thread.start()

這種情況的代碼運行情況如下:

復制代碼 代碼如下:

I am Thread-1, set counter:1

之后就直接掛起了,這種情況形成了最簡單的死鎖。

那有沒有一種情況可以在某一個線程使用互斥鎖訪問某一個競爭資源時,可以再次獲取呢?在Python中為了支持在同一線程中多次請求同一資源,python提供了“可重入鎖”:threading.RLock。這個RLock內部維護著一個Lock和一個counter變量,counter記錄了acquire的次數,從而使得資源可以被多次require。直到一個線程所有的acquire都被release,其他的線程才能獲得資源。上面的例子如果使用RLock代替Lock,則不會發生死鎖:

代碼只需將上述的:

復制代碼 代碼如下:

mutex = threading.Lock()

替換成:
復制代碼 代碼如下:

mutex = threading.RLock()

即可。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 屏南县| 荃湾区| 体育| 肇源县| 玛多县| 射洪县| 壶关县| 蒲江县| 宣汉县| 黄大仙区| 青岛市| 四川省| 迭部县| 泰宁县| 乐东| 河东区| 彭州市| 西丰县| 斗六市| 礼泉县| 浦江县| 读书| 大渡口区| 北川| 辽宁省| 惠水县| 张家川| 宣恩县| 增城市| 澜沧| 绥芬河市| 黄陵县| 类乌齐县| 玉门市| 潞城市| 班玛县| 谢通门县| 南部县| 龙门县| 修水县| 武强县|