久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

python多進程 主進程和子進程間共享和不共享全局變量實例

瀏覽:2日期:2022-07-27 14:51:46

Python 多進程默認不能共享全局變量

主進程與子進程是并發(fā)執(zhí)行的,進程之間默認是不能共享全局變量的(子進程不能改變主進程中全局變量的值)。

如果要共享全局變量需要用(multiprocessing.Value('d',10.0),數(shù)值)(multiprocessing.Array('i',[1,2,3,4,5]),數(shù)組)(multiprocessing.Manager().dict(),字典)(multiprocessing.Manager().list(range(5)))。

進程通信(進程之間傳遞數(shù)據(jù))用進程隊列(multiprocessing.Queue(),單向通信),管道( multiprocessing.Pipe() ,雙向通信)。

python多進程 主進程和子進程間共享和不共享全局變量實例

import multiprocessingimport timeimport os datalist=[’+++’] #全局變量,主進程與子進程是并發(fā)執(zhí)行的,他們不能共享全局變量(子進程不能改變主進程中全局變量的值) def adddata(): global datalist datalist.append(1) datalist.append(2) datalist.append(3) print('子進程',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('主進程',os.getpid(),datalist)

Python 進程之間共享數(shù)據(jù)(全局變量)

進程之間共享數(shù)據(jù)(數(shù)值型):

import multiprocessing def func(num): num.value=10.78 #子進程改變數(shù)值的值,主進程跟著改變 if __name__=='__main__': num=multiprocessing.Value('d',10.0) # d表示數(shù)值,主進程與子進程共享這個value。(主進程與子進程都是用的同一個value) print(num.value) p=multiprocessing.Process(target=func,args=(num,)) p.start() p.join() print(num.value)

進程之間共享數(shù)據(jù)(數(shù)組型):

import multiprocessing def func(num): num[2]=9999 #子進程改變數(shù)組,主進程跟著改變 if __name__=='__main__': num=multiprocessing.Array('i',[1,2,3,4,5]) #主進程與子進程共享這個數(shù)組 print(num[:]) p=multiprocessing.Process(target=func,args=(num,)) p.start() p.join() print(num[:])

進程之間共享數(shù)據(jù)(dict,list):

import multiprocessing def func(mydict,mylist): mydict['index1']='aaaaaa' #子進程改變dict,主進程跟著改變 mydict['index2']='bbbbbb' mylist.append(11) #子進程改變List,主進程跟著改變 mylist.append(22) mylist.append(33) if __name__=='__main__': with multiprocessing.Manager() as MG: #重命名 mydict=multiprocessing.Manager().dict() #主進程與子進程共享這個字典 mylist=multiprocessing.Manager().list(range(5)) #主進程與子進程共享這個List p=multiprocessing.Process(target=func,args=(mydict,mylist)) p.start() p.join() print(mylist) print(mydict)

多線程用全局變量(global)

以上這篇python多進程 主進程和子進程間共享和不共享全局變量實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 昆山市| 沅江市| 和龙市| 崇礼县| 云南省| 郴州市| 米泉市| 英吉沙县| 布拖县| 恩施市| 唐河县| 满洲里市| 威宁| 湘阴县| 铜鼓县| 唐海县| 武宣县| 阳原县| 黎川县| 麻城市| 融水| 崇文区| 莒南县| 渭南市| 垣曲县| 房产| 三明市| 荣成市| 百色市| 大关县| 永靖县| 墨竹工卡县| 上犹县| 奉贤区| 馆陶县| 陕西省| 乐平市| 武强县| 慈利县| 怀仁县| 巩义市|