欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python多進程協(xié)作模擬實現(xiàn)流程

 更新時間:2023年01月17日 10:15:46   作者:永遠的麥田  
當多個進程使用同一份數(shù)據(jù)資源的時候,因為進程的運行沒有順序,運行起來也無法控制,如果不加以干預(yù),往往會引發(fā)數(shù)據(jù)安全或順序混亂的問題,所以要在多個進程讀寫共享數(shù)據(jù)資源的時候加以適當?shù)牟呗?,來保證數(shù)據(jù)的一致性問題

由于python多線程無法發(fā)揮多核的作用,因此當計算量很大的時候就需要考慮多進程。

只不過多進程比較麻煩一些,進程中通信向來是一件麻煩事。

python提供了multiprocessing 模塊,應(yīng)該會提供不少便利

假設(shè)我們做量化交易需要運行一個算法,針對一只票每運行一次需要30秒,運行完成將結(jié)果作為一個因子交給另一個計算模塊運行,最后將計算結(jié)果統(tǒng)計出來。如果只運行一只票問題不大,大不了等一下就好,同時運行10票的話就很有必然考慮多進程以加快速度。

pro_queue為生產(chǎn)進程的數(shù)據(jù)隊列,生產(chǎn)進程完成生產(chǎn)后將自己相關(guān)數(shù)據(jù)裝產(chǎn)pro_queue中

calc_queue為計算進程的數(shù)據(jù)隊列,計算進程先將生產(chǎn)進程的數(shù)據(jù)通過參數(shù)傳遞的方式獲取到,然后進行計算,并將計算結(jié)果存入calc_queue中

主進程在最后不斷獲取計算進程的計算結(jié)果,并將其累加,最終獲取到一個總的計算結(jié)果

生產(chǎn)進程:

def func_a(i, p: queues):
    print(F"第{i}個生產(chǎn)進程: 進程號:{os.getpid()},開始...")
    time.sleep(random.randint(1, 5))
    result = random.randint(50, 100)
    print(F"第{i}個生產(chǎn)進程: 完成。生產(chǎn)結(jié)果[{result}]。")
    p.put((i, os.getpid(), result))

計算進程:

def func_b(i, data, q: queues):
    print(F"第{i}個計算進程: 進程號:{os.getpid()}, 數(shù)據(jù)源{data[0]}:{data[1]}:{data[2]},開始...")
    time.sleep(random.randint(1, 3))
    result = data[2] * 100
    print(F"第{i}個計算進程: 完成。計算結(jié)果【{result}】")
    q.put(result)

程序一開始先將生產(chǎn)進程啟動起來:其中process_num表示同時啟動多少個生產(chǎn)進程

    for i in range(process_num):
        p = Process(target=func_a, args=(i, pro_queue,))
        p.start()

然后不停等待生產(chǎn)進程的結(jié)果,每等到一個結(jié)果就啟動一個計算進程

    for i in range(process_num):
        data = pro_queue.get()
        p = Process(target=func_b, args=(i, data, calc_queue))
        p.start()

最后就是等待計算進程的計算結(jié)果

    s = 0
    for i in range(process_num):
        s += calc_queue.get()
    print(F"所有計算完成,總結(jié)果:{s}")

補上程序一開始的兩個隊列的申明:

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多進程協(xié)作模擬實現(xiàn)流程的文章就介紹到這了,更多相關(guān)Python多進程協(xié)作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論