python并發(fā)編程多進(jìn)程 互斥鎖原理解析
運行多進(jìn)程 每個子進(jìn)程的內(nèi)存空間是互相隔離的 進(jìn)程之間數(shù)據(jù)不能共享的
互斥鎖
但是進(jìn)程之間都是運行在一個操作系統(tǒng)上,進(jìn)程之間數(shù)據(jù)不共享,但是共享同一套文件系統(tǒng),所以訪問同一個文件,或同一個打印終端,
是可以的,而共享帶來的是競爭,競爭帶來的結(jié)果就是錯亂
#并發(fā)運行,效率高,但競爭同一打印終端,帶來了打印錯亂
from multiprocessing import Process
import time
def task(name):
print("%s 1" % name)
time.sleep(1)
print("%s 2" % name)
time.sleep(1)
print("%s 3" % name)
if __name__ == '__main__':
for i in range(3):
p = Process(target=task, args=("子進(jìn)程%s" % i,))
p.start()
'''
子進(jìn)程2 1
子進(jìn)程0 1
子進(jìn)程1 1
子進(jìn)程2 2
子進(jìn)程1 2
子進(jìn)程0 2
子進(jìn)程2 3
子進(jìn)程1 3
子進(jìn)程0 3
'''
如何控制,就是加鎖處理。而互斥鎖的意思就是互相排斥,如果把多個進(jìn)程比喻為多個人,
互斥鎖的工作原理就是多個人都要去爭搶同一個資源:衛(wèi)生間,一個人搶到衛(wèi)生間后上一把鎖,其他人都要等著,等到這個完成任務(wù)后釋放鎖,其他人才有可能有一個搶到......
所以互斥鎖的原理,就是把并發(fā)改成串行,降低了效率,但保證了數(shù)據(jù)安全,不錯亂
加了互斥鎖就沒有并發(fā)效果了 加上鎖只有一個可以運行 互斥鎖會把并發(fā)變成串行 效率變低了
解決:
導(dǎo)入模塊 Lock
現(xiàn)在程序啟動 所有進(jìn)程首先會去搶鎖 只有搶到鎖的才能運行
等這個進(jìn)程運行完了解鎖后 再到其他進(jìn)程繼續(xù)搶鎖
from multiprocessing import Process, Lock
import time
def task(name, mutex):
# 加鎖
mutex.acquire()
print("%s 1" % name)
time.sleep(1)
print("%s 2" % name)
time.sleep(1)
print("%s 3" % name)
# 把鎖拆了
mutex.release()
if __name__ == '__main__':
# 建一個對象實例
mutex = Lock()
for i in range(3):
# 把鎖傳給子進(jìn)程 讓所有子進(jìn)程用同一把鎖
p = Process(target=task, args=("子進(jìn)程%s" % i, mutex))
p.start()
'''
現(xiàn)在程序啟動 所有進(jìn)程首先會去搶鎖 只有搶到鎖的才能運行
等這個進(jìn)程運行完了解鎖后 再到其他進(jìn)程繼續(xù)搶鎖
'''
'''
子進(jìn)程0 1
子進(jìn)程0 2
子進(jìn)程0 3
子進(jìn)程1 1
子進(jìn)程1 2
子進(jìn)程1 3
子進(jìn)程2 1
子進(jìn)程2 2
子進(jìn)程2 3
'''
犧牲了效率,保證數(shù)據(jù)不錯亂
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
PyTorch中的方法torch.randperm()示例介紹
在 PyTorch 中,torch.randperm(n) 函數(shù)用于生成一個從 0 到 n-1 的隨機(jī)排列的整數(shù)序列,這篇文章主要介紹了PyTorch中的方法torch.randperm()介紹,需要的朋友可以參考下2024-05-05
pandas.DataFrame 根據(jù)條件新建列并賦值的方法
下面小編就為大家分享一篇pandas.DataFrame 根據(jù)條件新建列并賦值的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04
xshell會話批量遷移到mobaxterm的工具(python小工具)
這篇文章主要介紹了xshell會話批量遷移到mobaxterm的工具,使用方法也超級簡單,本文通過python代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-12-12
Python如何在ubuntu中更改Python和pip指向
這篇文章主要介紹了Python如何在ubuntu中更改Python和pip指向問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08

