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