python進程之間如何通信
本文教程操作環境:windows7系統、Python3.9.1,DELLG3電腦。
1、思路
Process之間肯定是需要通信的,操作系統提供了很多機制來實現進程間的通信。Python的multiprocessing模塊包裝了底層的機制,提供了Queue、Pipes等多種方式來交換數據。
2、實例
以Queue為例,在父進程中創建兩個子進程,一個往Queue里寫數據,一個從Queue里讀數據。
frommultiprocessingimportProcess,Queue
importos,time,random
#寫數據進程執行的代碼:
defwrite(q):
print('Processtowrite:%s'%os.getpid())
forvaluein['A','B','C']:
print('Put%stoqueue...'%value)
q.put(value)
time.sleep(random.random())
#讀數據進程執行的代碼:
defread(q):
print('Processtoread:%s'%os.getpid())
whileTrue:
value=q.get(True)
print('Get%sfromqueue.'%value)
if__name__=='__main__':
#父進程創建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進程里是死循環,無法等待其結束,只能強行終止:
pr.terminate()
以上就是python進程之間通信的方法,希望能對大家有所幫助。更多Python學習教程請關注IT培訓機構:千鋒教育。