亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python多進(jìn)程 主進(jìn)程和子進(jìn)程間共享和不共享全局變量實(shí)例

 更新時(shí)間:2020年04月25日 14:48:09   作者:JackLiu16  
這篇文章主要介紹了python多進(jìn)程 主進(jìn)程和子進(jìn)程間共享和不共享全局變量實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

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è)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論