更新時(shí)間:2023-11-03 來(lái)源:黑馬程序員 瀏覽量:
互斥鎖是對(duì)共享數(shù)據(jù)進(jìn)行鎖定,保證同一時(shí)刻只能有一個(gè)線程去操作??梢岳斫鉃槎鄠€(gè)線程一起搶鎖,搶到鎖的線程先執(zhí)行,沒(méi)有搶到鎖的線程需要等待,等互斥鎖使用完釋放后,其它等待的線程再去搶這個(gè)鎖。
threading模塊中定義了Lock變量,這個(gè)變量本質(zhì)上是一個(gè)函數(shù),通過(guò)調(diào)用這個(gè)函數(shù)可以獲取一把互斥鎖?;コ怄i使用步驟如下:
# 創(chuàng)建鎖 mutex = threading.Lock() # 上鎖 mutex.acquire() ...這里編寫(xiě)代碼能保證同一時(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è)互斥鎖釋放后才能再次上鎖。