python的concurrent.futures.ThreadPoolExecutor

Quickstart

from concurrent import futures


def fib(n):
    if n == 0 or n == 1:
        return 1
    return fib(n-1) + fib(n-2)

# base
with futures.ThreadPoolExecutor() as executor:
    f1 = executor.submit(fib, 4) # return future
    f2 = executor.submit(fib, 5)

print(f1.result())
print(f2.result())


FIBS = [3, 7, 10, 20]
# advance
with futures.ThreadPoolExecutor(max_workers=5) as executor:
    future_to_num = {executor.submit(fib, num): num for num in FIBS}
    for future in futures.as_completed(future_to_num):
        print(future.result(), future_to_num[future])

# map
with futures.ThreadPoolExecutor(max_workers=5) as executor:
    for num, res in zip(FIBS, executor.map(fib, FIBS)):
        print(num, res)

HOW-TO

通過改變max_workers 來提速

通過改變chunksize 來加速

chunksize表示每個進程完成多少次函數(shù)計算之后 會被殺死掉 默認是1個


FIBS = [1, 3, 5, 7] * 5


def do_calculate(chunksize=1):
    with futures.ProcessPoolExecutor(max_workers=5) as executor:
        for num, ret in zip(FIBS, executor.map(fib, FIBS, chunksize=chunksize)):
            pass


def main():
    for num in FIBS:
        fib(num)
        
(3.6)  ~/Documents/code/zhangyu/learn_python/test_concurrent   master ●  python -m perf timeit 'from concur import do_calculate,main;do_calculate(5)' --quiet
Mean +- std dev: 28.4 ms +- 0.8 ms
(3.6)  ~/Documents/code/zhangyu/learn_python/test_concurrent   master ●  python -m perf timeit 'from concur import do_calculate,main;do_calculate(1)' --quiet
Mean +- std dev: 19.1 ms +- 1.3 ms
(3.6)  ~/Documents/code/zhangyu/learn_python/test_concurrent   master ●  python -m perf timeit 'from concur import do_calculate,main;do_calculate(3)' --quiet
Mean +- std dev: 15.2 ms +- 0.7 ms
(3.6)  ~/Documents/code/zhangyu/learn_python/test_concurrent   master ●  python -m perf timeit 'from concur import do_calculate,main;do_calculate(30)' --quiet
Mean +- std dev: 13.8 ms +- 0.6 ms
(3.6)  ~/Documents/code/zhangyu/learn_python/test_concurrent   master ●  python -m perf timeit 'from concur import do_calculate,main;main()' --quiet
Mean +- std dev: 64.9 us +- 1.6 us
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容