python多進(jìn)程 主進(jìn)程和子進(jìn)程間共享和不共享全局變量實(shí)例
Python 多進(jìn)程默認(rèn)不能共享全局變量
主進(jìn)程與子進(jìn)程是并發(fā)執(zhí)行的,進(jìn)程之間默認(rèn)是不能共享全局變量的(子進(jìn)程不能改變主進(jìn)程中全局變量的值)。
如果要共享全局變量需要用(multiprocessing.Value('d',10.0),數(shù)值)(multiprocessing.Array('i',[1,2,3,4,5]),數(shù)組)(multiprocessing.Manager().dict(),字典)(multiprocessing.Manager().list(range(5)))。
進(jìn)程通信(進(jìn)程之間傳遞數(shù)據(jù))用進(jìn)程隊(duì)列(multiprocessing.Queue(),單向通信),管道( multiprocessing.Pipe() ,雙向通信)。
import multiprocessingimport timeimport os datalist=[’+++’] #全局變量,主進(jìn)程與子進(jìn)程是并發(fā)執(zhí)行的,他們不能共享全局變量(子進(jìn)程不能改變主進(jìn)程中全局變量的值) def adddata(): global datalist datalist.append(1) datalist.append(2) datalist.append(3) print('子進(jìn)程',os.getpid(),datalist) if __name__=='__main__': p=multiprocessing.Process(target=adddata,args=()) p.start() p.join() datalist.append('a') datalist.append('b') datalist.append('c') print('主進(jìn)程',os.getpid(),datalist)
Python 進(jìn)程之間共享數(shù)據(jù)(全局變量)
進(jìn)程之間共享數(shù)據(jù)(數(shù)值型):
import multiprocessing def func(num): num.value=10.78 #子進(jìn)程改變數(shù)值的值,主進(jìn)程跟著改變 if __name__=='__main__': num=multiprocessing.Value('d',10.0) # d表示數(shù)值,主進(jìn)程與子進(jìn)程共享這個(gè)value。(主進(jìn)程與子進(jìn)程都是用的同一個(gè)value) print(num.value) p=multiprocessing.Process(target=func,args=(num,)) p.start() p.join() print(num.value)
進(jìn)程之間共享數(shù)據(jù)(數(shù)組型):
import multiprocessing def func(num): num[2]=9999 #子進(jìn)程改變數(shù)組,主進(jìn)程跟著改變 if __name__=='__main__': num=multiprocessing.Array('i',[1,2,3,4,5]) #主進(jìn)程與子進(jìn)程共享這個(gè)數(shù)組 print(num[:]) p=multiprocessing.Process(target=func,args=(num,)) p.start() p.join() print(num[:])
進(jìn)程之間共享數(shù)據(jù)(dict,list):
import multiprocessing def func(mydict,mylist): mydict['index1']='aaaaaa' #子進(jìn)程改變dict,主進(jìn)程跟著改變 mydict['index2']='bbbbbb' mylist.append(11) #子進(jìn)程改變List,主進(jìn)程跟著改變 mylist.append(22) mylist.append(33) if __name__=='__main__': with multiprocessing.Manager() as MG: #重命名 mydict=multiprocessing.Manager().dict() #主進(jìn)程與子進(jìn)程共享這個(gè)字典 mylist=multiprocessing.Manager().list(range(5)) #主進(jìn)程與子進(jìn)程共享這個(gè)List p=multiprocessing.Process(target=func,args=(mydict,mylist)) p.start() p.join() print(mylist) print(mydict)
多線程用全局變量(global)
以上這篇python多進(jìn)程 主進(jìn)程和子進(jìn)程間共享和不共享全局變量實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ASP基礎(chǔ)入門第三篇(ASP腳本基礎(chǔ))2. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案3. phpstudy apache開啟ssi使用詳解4. 解析原生JS getComputedStyle5. IE6/IE7/IE8/IE9中tbody的innerHTML不能賦值的完美解決方案6. XML解析錯(cuò)誤:未組織好 的解決辦法7. XML入門的常見問題(二)8. 阿里前端開發(fā)中的規(guī)范要求9. ASP基礎(chǔ)入門第八篇(ASP內(nèi)建對(duì)象Application和Session)10. ASP中格式化時(shí)間短日期補(bǔ)0變兩位長(zhǎng)日期的方法
