Python通過4種方式實(shí)現(xiàn)進(jìn)程數(shù)據(jù)通信
python提供了4種方式來滿足進(jìn)程間的數(shù)據(jù)通信
1. 使用multiprocessing.Queue可以在進(jìn)程間通信,但不能在Pool池創(chuàng)建的進(jìn)程間進(jìn)行通信
2. 使用multiprocessing.Manager.Queue可以在Pool進(jìn)程池創(chuàng)建的進(jìn)程間進(jìn)行通信
3. 通過Pipe進(jìn)行線程間的通信, pipe進(jìn)程間通信的性能高于Queue,但是它只能在兩個(gè)進(jìn)程間進(jìn)行通信
4. 使用Manager類提供的數(shù)據(jù)結(jié)構(gòu)可以進(jìn)行進(jìn)程間的通信
from multiprocessing import Process, Queue, Pool, Manager, Pipe # 注意線程間的通信,使用的queue.Queue # from queue import Queue import time # 1. 使用multiprocessing.Queue可以在進(jìn)程間通信 # def producer(queue): # queue.put('A') # time.sleep(2) # # def consumer(queue): # time.sleep(2) # data = queue.get() # print(data) # # if __name__ == '__main__': # queue= Queue(10) # p = Process(target=producer, args=(queue,)) # c = Process(target=consumer, args=(queue,)) # p.start() # c.start() # p.join() # c.join() # 2. 使用共享全局變量,在多進(jìn)程間通信(結(jié)論: 不行) # def producer(a): # a += 1 # time.sleep(2) # # # def consumer(a): # time.sleep(2) # print(a) # # if __name__ == '__main__': # a = 1 # p = Process(target=producer, args=(a,)) # c = Process(target=consumer, args=(a,)) # p.start() # c.start() # p.join() # c.join() # 3. multiprocessing.Queue不能用于multiprocessing.Pool進(jìn)程池創(chuàng)建的進(jìn)程間進(jìn)行通信 # def producer(queue): # queue.put('A') # time.sleep(2) # # # def consumer(queue): # time.sleep(2) # data = queue.get() # print("consumer:%s" % data) # # # if __name__ == '__main__': # # queue = Queue(10) # 這個(gè)是使用multiprocessing.Queue,無效 # queue = Manager().Queue(10) # 這個(gè)是使用multiprocessing.Manager.Queue, 可以 # pool = Pool(2) # pool.apply_async(producer, args=(queue,)) # pool.apply_async(consumer, args=(queue,)) # pool.close() # pool.join() # 4.通過Pipe進(jìn)行線程間的通信, pipe進(jìn)程間通信的性能高于Queue # def producer(pipe): # pipe.send('admin') # # # def consumer(pipe): # data = pipe.recv() # print("consumer:%s" % data) # # # if __name__ == '__main__': # receive_pipe, send_pipe = Pipe() # """Pipe只能適應(yīng)于兩個(gè)進(jìn)程間的通信""" # p = Process(target=producer, args=(send_pipe,)) # c = Process(target=consumer, args=(receive_pipe,)) # p.start() # c.start() # p.join() # c.join() # 5. 進(jìn)程間通信的其它方式 def add_data(p_dict, key, value): p_dict[key] = value if __name__ == '__main__': progress_dict = Manager().dict() #Manager()類中提供的數(shù)據(jù)結(jié)構(gòu)都能夠做到進(jìn)程的通信 first_progress = Process(target=add_data, args=(progress_dict, 'name', 'admin',)) second_progress = Process(target=add_data, args=(progress_dict, 'age', 45,)) first_progress.start() second_progress.start() first_progress.join() second_progress.join() print(progress_dict) #{'age': 45, 'name': 'admin'}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在Python中使用NLTK庫(kù)實(shí)現(xiàn)對(duì)詞干的提取的教程
這篇文章主要介紹了在Python中使用NLTK庫(kù)實(shí)現(xiàn)對(duì)詞干的提取的教程,其中還用到了Pandas和IPython,需要的朋友可以參考下2015-04-04python如何統(tǒng)計(jì)代碼運(yùn)行的時(shí)長(zhǎng)
這篇文章主要介紹了python如何統(tǒng)計(jì)代碼運(yùn)行的時(shí)長(zhǎng),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07python?數(shù)據(jù)保存為npy和npz格式并讀取的完整代碼
這篇文章主要介紹了python?數(shù)據(jù)保存為npy和npz格式并讀取,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07Python實(shí)戰(zhàn)小項(xiàng)目之身份證信息校驗(yàn)
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用Python做一個(gè)身份證信息校驗(yàn)的小項(xiàng)目,大家可以在過程中查缺補(bǔ)漏,提升水平2021-10-10對(duì)python創(chuàng)建及引用動(dòng)態(tài)變量名的示例講解
今天小編就為大家分享一篇對(duì)python創(chuàng)建及引用動(dòng)態(tài)變量名的示例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-11-11python實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03