Python多進(jìn)程協(xié)作模擬實(shí)現(xiàn)流程
由于python多線程無法發(fā)揮多核的作用,因此當(dāng)計(jì)算量很大的時(shí)候就需要考慮多進(jìn)程。
只不過多進(jìn)程比較麻煩一些,進(jìn)程中通信向來是一件麻煩事。
python提供了multiprocessing 模塊,應(yīng)該會(huì)提供不少便利
假設(shè)我們做量化交易需要運(yùn)行一個(gè)算法,針對(duì)一只票每運(yùn)行一次需要30秒,運(yùn)行完成將結(jié)果作為一個(gè)因子交給另一個(gè)計(jì)算模塊運(yùn)行,最后將計(jì)算結(jié)果統(tǒng)計(jì)出來。如果只運(yùn)行一只票問題不大,大不了等一下就好,同時(shí)運(yùn)行10票的話就很有必然考慮多進(jìn)程以加快速度。
pro_queue為生產(chǎn)進(jìn)程的數(shù)據(jù)隊(duì)列,生產(chǎn)進(jìn)程完成生產(chǎn)后將自己相關(guān)數(shù)據(jù)裝產(chǎn)pro_queue中
calc_queue為計(jì)算進(jìn)程的數(shù)據(jù)隊(duì)列,計(jì)算進(jìn)程先將生產(chǎn)進(jìn)程的數(shù)據(jù)通過參數(shù)傳遞的方式獲取到,然后進(jìn)行計(jì)算,并將計(jì)算結(jié)果存入calc_queue中
主進(jìn)程在最后不斷獲取計(jì)算進(jìn)程的計(jì)算結(jié)果,并將其累加,最終獲取到一個(gè)總的計(jì)算結(jié)果
生產(chǎn)進(jìn)程:
def func_a(i, p: queues): print(F"第{i}個(gè)生產(chǎn)進(jìn)程: 進(jìn)程號(hào):{os.getpid()},開始...") time.sleep(random.randint(1, 5)) result = random.randint(50, 100) print(F"第{i}個(gè)生產(chǎn)進(jìn)程: 完成。生產(chǎn)結(jié)果[{result}]。") p.put((i, os.getpid(), result))
計(jì)算進(jìn)程:
def func_b(i, data, q: queues): print(F"第{i}個(gè)計(jì)算進(jìn)程: 進(jìn)程號(hào):{os.getpid()}, 數(shù)據(jù)源{data[0]}:{data[1]}:{data[2]},開始...") time.sleep(random.randint(1, 3)) result = data[2] * 100 print(F"第{i}個(gè)計(jì)算進(jìn)程: 完成。計(jì)算結(jié)果【{result}】") q.put(result)
程序一開始先將生產(chǎn)進(jìn)程啟動(dòng)起來:其中process_num表示同時(shí)啟動(dòng)多少個(gè)生產(chǎn)進(jìn)程
for i in range(process_num): p = Process(target=func_a, args=(i, pro_queue,)) p.start()
然后不停等待生產(chǎn)進(jìn)程的結(jié)果,每等到一個(gè)結(jié)果就啟動(dòng)一個(gè)計(jì)算進(jìn)程
for i in range(process_num): data = pro_queue.get() p = Process(target=func_b, args=(i, data, calc_queue)) p.start()
最后就是等待計(jì)算進(jìn)程的計(jì)算結(jié)果
s = 0 for i in range(process_num): s += calc_queue.get() print(F"所有計(jì)算完成,總結(jié)果:{s}")
補(bǔ)上程序一開始的兩個(gè)隊(duì)列的申明:
import multiprocessing import time from multiprocessing import Process from multiprocessing import queues import random import os pro_queue = queues.Queue(ctx=multiprocessing) calc_queue = queues.Queue(ctx=multiprocessing) process_num = 5
到此這篇關(guān)于Python多進(jìn)程協(xié)作模擬實(shí)現(xiàn)流程的文章就介紹到這了,更多相關(guān)Python多進(jìn)程協(xié)作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python判斷一個(gè)文件夾內(nèi)哪些文件是圖片的實(shí)例
今天小編就為大家分享一篇Python判斷一個(gè)文件夾內(nèi)哪些文件是圖片的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-12-12python實(shí)現(xiàn)簡(jiǎn)單的udp發(fā)送和接收
這篇文章主要介紹了python實(shí)現(xiàn)簡(jiǎn)單的udp發(fā)送和接收方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Python多線程、異步+多進(jìn)程爬蟲實(shí)現(xiàn)代碼
這篇文章主要介紹了Python多線程、異步+多進(jìn)程爬蟲實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-02-02Python 訪問限制 private public的詳細(xì)介紹
在一個(gè)模塊中,我們可能會(huì)定義很多函數(shù)和變量。這篇文章主要介紹了Python 訪問限制 private public的詳細(xì)介紹,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-10-10Pyinstaller 打包發(fā)布經(jīng)驗(yàn)總結(jié)
這篇文章主要介紹了Pyinstaller 打包發(fā)布經(jīng)驗(yàn)總結(jié),使用Pyinstaller打包Python項(xiàng)目包含了大量的坑,感興趣的可以一起來了解一下2020-06-06python腳本框架webpy模板賦值實(shí)現(xiàn)
這篇文章主要為大家介紹了python腳本框架webpy模板賦值實(shí)現(xiàn)示例過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-11-11