您好,登錄后才能下訂單哦!
主進程與子進程是并發執行的,進程之間默認是不能共享全局變量的(子進程不能改變主進程中全局變量的值)。如果要共享全局變量需要用(multiprocessing.Value("d",10.0),數值)(multiprocessing.Array("i",[1,2,3,4,5]),數組)(multiprocessing.Manager().dict(),字典)(multiprocessing.Manager().list(range(5)))。進程通信(進程之間傳遞數據)用進程隊列(multiprocessing.Queue(),單向通信),管道( multiprocessing.Pipe() ,雙向通信)。
import multiprocessing import time import os datalist=['+++'] #全局變量,主進程與子進程是并發執行的,他們不能共享全局變量(子進程不能改變主進程中全局變量的值) 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 多進程默認不能共享全局變量的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。