首頁(yè)技術(shù)文章正文

互斥鎖是什么?互斥鎖的具體使用步驟

更新時(shí)間:2023-11-03 來源:黑馬程序員 瀏覽量:

互斥鎖是對(duì)共享數(shù)據(jù)進(jìn)行鎖定,保證同一時(shí)刻只能有一個(gè)線程去操作。可以理解為多個(gè)線程一起搶鎖,搶到鎖的線程先執(zhí)行,沒有搶到鎖的線程需要等待,等互斥鎖使用完釋放后,其它等待的線程再去搶這個(gè)鎖。

threading模塊中定義了Lock變量,這個(gè)變量本質(zhì)上是一個(gè)函數(shù),通過調(diào)用這個(gè)函數(shù)可以獲取一把互斥鎖?;コ怄i使用步驟如下:

# 創(chuàng)建鎖
mutex = threading.Lock()

# 上鎖
mutex.acquire()

...這里編寫代碼能保證同一時(shí)刻只能有一個(gè)線程去操作, 對(duì)共享數(shù)據(jù)進(jìn)行鎖定...# 釋放鎖mutex.release()

# 釋放鎖
mutex.release()

注意點(diǎn):acquire和release方法之間的代碼同一時(shí)刻只能有一個(gè)線程去操作

如果在調(diào)用acquire方法的時(shí)候 其他線程已經(jīng)使用了這個(gè)互斥鎖,那么此時(shí)acquire方法會(huì)堵塞,直到這個(gè)互斥鎖釋放后才能再次上鎖。


分享到:
在線咨詢 我要報(bào)名
和我們?cè)诰€交談!