Python多進程-進程間數據的傳遞


兩個進程間的數據是獨立的,要進行數據傳遞的話可通過幾個方法

Queue

通過隊列來進行進程間數據的傳遞

# -*- coding:utf-8 -*-
__author__ = "MuT6 Sch01aR"

from multiprocessing import Process, Queue

def Child_Process(n):
    n.put("Data From Child Process")

if __name__ == '__main__':
    q = Queue()
    p = Process(target=Child_Process, args=(q,))
    p.start()
    print(q.get())
    p.join()

 運行結果

父進程中聲明了一個queue,也生成了一個子進程,然后父進程把queue克隆一份,然后通過pickle序列化queue,再把queue進行pickle反序列化傳入子進程

兩個進程之間通過進程queue進行數據傳遞需要經過pickle的序列化和反序列化

Pipe

通過管道來進行進程間數據的傳遞

# -*- coding:utf-8 -*-
__author__ = "MuT6 Sch01aR"

from multiprocessing import Process, Pipe

def f(conn):
    conn.send("Data_1 from Conn_1")
    conn.send("Data_2 from Conn_1")
    print("Conn_1: ",conn.recv())
    conn.close()

if __name__ == '__main__':
    conn_1, conn_2 = Pipe() #生成管道的兩邊,分別傳給兩個進程
    p = Process(target=f, args=(conn_1,))
    p.start()
    print("Conn_2: ",conn_2.recv())
    print("Conn_2: ",conn_2.recv())
    conn_2.send("Data_1 from Conn_2")
    p.join()

 運行結果

上面是兩邊的管道收發數據的次數一樣,如果把conn_2給conn_1發送數據的那一行代碼去掉

腳本就會在conn_1接收數據處一直等着

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2026 CODEPRJ.COM