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 multiprocessing import time import 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è)參考,也希望大家多多支持腳本之家。
- python啟動(dòng)辦公軟件進(jìn)程(word、excel、ppt、以及wps的et、wps、wpp)
- Python子進(jìn)程subpocess原理及用法解析
- python TK庫(kù)簡(jiǎn)單應(yīng)用(實(shí)時(shí)顯示子進(jìn)程輸出)
- Python進(jìn)程,多進(jìn)程,獲取進(jìn)程id,給子進(jìn)程傳遞參數(shù)操作示例
- 在Python中os.fork()產(chǎn)生子進(jìn)程的例子
- 對(duì)Python subprocess.Popen子進(jìn)程管道阻塞詳解
- python清理子進(jìn)程機(jī)制剖析
- python subprocess 殺掉全部派生的子進(jìn)程方法
- 如何用 Python 子進(jìn)程關(guān)閉 Excel 自動(dòng)化中的彈窗
相關(guān)文章
python 使用sys.stdin和fileinput讀入標(biāo)準(zhǔn)輸入的方法
今天小編就為大家分享一篇python 使用sys.stdin和fileinput讀入標(biāo)準(zhǔn)輸入的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10Python使用itcaht庫(kù)實(shí)現(xiàn)微信自動(dòng)收發(fā)消息功能
這篇文章主要介紹了Python使用itcaht庫(kù)實(shí)現(xiàn)微信自動(dòng)收發(fā)消息功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07嘗試用最短的Python代碼來(lái)實(shí)現(xiàn)服務(wù)器和代理服務(wù)器
"人生苦短、我用Python",Python最大的特點(diǎn)便是代碼簡(jiǎn)潔,得益于Python自帶的wsgiref包和socket模塊,這里我們將嘗試用最短的Python代碼來(lái)實(shí)現(xiàn)服務(wù)器和代理服務(wù)器:2016-06-06python實(shí)戰(zhàn)游戲之史上最難最虐的掃雷游戲沒(méi)有之一
這篇文章主要介紹了使用 python 實(shí)現(xiàn)掃雷游戲,不同于傳統(tǒng)過(guò)時(shí)的掃雷,今天我們用 Python 增加了新花樣,文中給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09Python3按一定數(shù)據(jù)位數(shù)格式處理bin文件的方法
今天小編就為大家分享一篇Python3按一定數(shù)據(jù)位數(shù)格式處理bin文件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01pandas?dataframe寫(xiě)入到hive方式
這篇文章主要介紹了pandas?dataframe寫(xiě)入到hive方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08python讀取文件夾中圖片的圖片名并寫(xiě)入excel表格
這篇文章介紹了使用python讀取文件夾中圖片的圖片名并寫(xiě)入excel表格的方法。對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12