python進(jìn)程之間如何通信
本文教程操作環(huán)境:windows7系統(tǒng)、Python3.9.1,DELLG3電腦。
1、思路
Process之間肯定是需要通信的,操作系統(tǒng)提供了很多機(jī)制來實(shí)現(xiàn)進(jìn)程間的通信。Python的multiprocessing模塊包裝了底層的機(jī)制,提供了Queue、Pipes等多種方式來交換數(shù)據(jù)。
2、實(shí)例
以Queue為例,在父進(jìn)程中創(chuàng)建兩個(gè)子進(jìn)程,一個(gè)往Queue里寫數(shù)據(jù),一個(gè)從Queue里讀數(shù)據(jù)。
frommultiprocessingimportProcess,Queue
importos,time,random
#寫數(shù)據(jù)進(jìn)程執(zhí)行的代碼:
defwrite(q):
print('Processtowrite:%s'%os.getpid())
forvaluein['A','B','C']:
print('Put%stoqueue...'%value)
q.put(value)
time.sleep(random.random())
#讀數(shù)據(jù)進(jìn)程執(zhí)行的代碼:
defread(q):
print('Processtoread:%s'%os.getpid())
whileTrue:
value=q.get(True)
print('Get%sfromqueue.'%value)
if__name__=='__main__':
#父進(jìn)程創(chuàng)建Queue,并傳給各個(gè)子進(jìn)程:
q=Queue()
pw=Process(target=write,args=(q,))
pr=Process(target=read,args=(q,))
#啟動(dòng)子進(jìn)程pw,寫入:
pw.start()
#啟動(dòng)子進(jìn)程pr,讀取:
pr.start()
#等待pw結(jié)束:
pw.join()
#pr進(jìn)程里是死循環(huán),無法等待其結(jié)束,只能強(qiáng)行終止:
pr.terminate()
以上就是python進(jìn)程之間通信的方法,希望能對大家有所幫助。更多Python學(xué)習(xí)教程請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。