python 多線程與多進程效率測試
1、概述
在Python中,計算密集型任務適用于多進程,IO密集型任務適用于多線程
正常來講,多線程要比多進程效率更高,因為進程間的切換需要的資源和開銷更大,而線程相對更小,但是我們使用的Python大多數(shù)的解釋器是Cpython,眾所周知Cpython有個GIL鎖,導致執(zhí)行計算密集型任務時多線程實際只能是單線程,而且由于線程之間切換的開銷導致多線程往往比實際的單線程還要慢,所以在 python 中計算密集型任務通常使用多進程,因為各個進程有各自獨立的GIL,互不干擾。
而在IO密集型任務中,CPU時常處于等待狀態(tài),操作系統(tǒng)需要頻繁與外界環(huán)境進行交互,如讀寫文件,在網(wǎng)絡間通信等。在這期間GIL會被釋放,因而就可以使用真正的多線程。
上面都是理論,接下來實戰(zhàn)看看實際效果是否符合理論
2、代碼練習
"""多線程多進程模擬執(zhí)行效率"""
from multiprocessing import Pool
from threading import Thread
import time, math
def simulation_IO(a):
"""模擬IO操作"""
time.sleep(3)
def simulation_compute(a):
"""模擬計算密集型任務"""
for i in range(int(1e7)):
math.sin(40) + math.cos(40)
return
def normal_func(func):
"""普通方法執(zhí)行效率"""
for i in range(6):
func(i)
return
def mp(func):
"""進程池中的map方法"""
with Pool(processes=6) as p:
res = p.map(func, list(range(6)))
return
def asy(func):
"""進程池中的異步執(zhí)行"""
with Pool(processes=6) as p:
result = []
for j in range(6):
a = p.apply_async(func, args=(j, ))
result.append(a)
res = [j.get() for j in result]
def thread(func):
"""多線程方法"""
threads = []
for j in range(6):
t = Thread(target=func, args=(j, ))
threads.append(t)
t.start()
for t in threads:
t.join()
def showtime(f, func, name):
"""
計算并展示函數(shù)的運行時間
:param f: 多進程和多線程的方法
:param func: 多進程和多線程方法中需要傳入的函數(shù)
:param name: 方法的名字
:return:
"""
start_time = time.time()
f(func)
print(f"{name} time: {time.time() - start_time:.4f}s")
def main(func):
"""
運行程序的主函數(shù)
:param func: 傳入需要計算時間的函數(shù)名
"""
showtime(normal_func, func, "normal")
print()
print("------ 多進程 ------")
showtime(mp, func, "map")
showtime(asy, func, "async")
print()
print("----- 多線程 -----")
showtime(thread, func, "thread")
if __name__ == "__main__":
print("------------ 計算密集型 ------------")
func = simulation_compute
main(func)
print()
print()
print()
print("------------ IO 密集型 ------------")
func = simulation_IO
main(func)
3、運行結果

| 線性執(zhí)行 | 多進程(map) | 多進程(async) | 多線程 | |
|---|---|---|---|---|
| 計算密集型 | 16.0284s | 3.5236s | 3.4367s | 15.2142s |
| IO密集型 | 18.0201s | 3.0945s | 3.0809s | 3.0041s |
從表格中很明顯的可以看出:
- 計算密集型任務的速度:多進程 >多線程> 單進程/線程
- IO密集型任務速度: 多線程 > 多進程 > 單進程/線程。
所以,針對計算密集型任務使用多進程,針對IO密集型任務使用多線程
到此這篇關于python 多線程與多進程效率測試 的文章就介紹到這了,更多相關python 多線程內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Django框架實現(xiàn)的普通登錄案例【使用POST方法】
這篇文章主要介紹了Django框架實現(xiàn)的普通登錄案例,結合實例形式分析了Django框架使用POST方法進行頁面登錄、校驗等相關操作技巧,需要的朋友可以參考下2019-05-05
解決Keras TensorFlow 混編中 trainable=False設置無效問題
這篇文章主要介紹了解決Keras TensorFlow 混編中 trainable=False設置無效問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
多版本python的pip 升級后, pip2 pip3 與python版本失配解決方法
在本篇文章里小編給大家整理的是關于多版本python的pip 升級后, pip2 pip3 與python版本失配的解決方法內容,需要的朋友們學習下。2019-09-09
Python Pygame實戰(zhàn)之趣味籃球游戲的實現(xiàn)
這篇文章主要為大家分享了一個基于Python和Pygame實現(xiàn)的一個趣味籃球游戲,文中的示例代碼講解詳細,對我們學習Python有一定幫助,需要的可以參考一下2022-04-04
Python3 Tkinkter + SQLite實現(xiàn)登錄和注冊界面
這篇文章主要為大家詳細介紹了Python3 Tkinkter + SQLite實現(xiàn)登錄和注冊界面,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-11-11

