亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python中多線程與多進程對比的示例分析

發布時間:2021-06-16 15:11:17 來源:億速云 閱讀:166 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關Python中多線程與多進程對比的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

多線程適合于多io操作

多進程適合于耗cpu(計算)的操作

# 多進程編程
# 耗cpu的操作,用多進程編程, 對于io操作來說,使用多線程編程
import time
from concurrent.futures import ThreadPoolExecutor, as_completed
from concurrent.futures import ProcessPoolExecutor


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

if __name__ == '__main__':

  # 1. 對于耗cpu操作,多進程優于多線程

  # with ThreadPoolExecutor(3) as executor:
  #   all_task = [executor.submit(fib, num) for num in range(25, 35)]
  #   start_time = time.time()
  #   for future in as_completed(all_task):
  #     data = future.result()
  #     print(data)
  #   print("last time :{}".format(time.time() - start_time)) # 3.905290126800537

  # 多進程 ,在window環境 下必須放在main方法中執行,否則拋異常
  with ProcessPoolExecutor(3) as executor:
    all_task = [executor.submit(fib, num) for num in range(25, 35)]
    start_time = time.time()
    for future in as_completed(all_task):
      data = future.result()
      print(data)
    print("last time :{}".format(time.time() - start_time)) # 2.6130592823028564

可以看到在耗cpu的應用中,多進程明顯優于多線程 2.6130592823028564 < 3.905290126800537

下面模擬一個io操作

# 多進程編程
# 耗cpu的操作,用多進程編程, 對于io操作來說,使用多線程編程
import time
from concurrent.futures import ThreadPoolExecutor, as_completed
from concurrent.futures import ProcessPoolExecutor

def io_operation(n):
  time.sleep(2)
  return n


if __name__ == '__main__':

  # 1. 對于耗cpu操作,多進程優于多線程

  # with ThreadPoolExecutor(3) as executor:
  #   all_task = [executor.submit(io_operation, num) for num in range(25, 35)]
  #   start_time = time.time()
  #   for future in as_completed(all_task):
  #     data = future.result()
  #     print(data)
  #   print("last time :{}".format(time.time() - start_time)) # 8.00358772277832



  # 多進程 ,在window環境 下必須放在main方法中執行,否則拋異常
  with ProcessPoolExecutor(3) as executor:
    all_task = [executor.submit(io_operation, num) for num in range(25, 35)]
    start_time = time.time()
    for future in as_completed(all_task):
      data = future.result()
      print(data)
    print("last time :{}".format(time.time() - start_time)) # 8.12435245513916

關于“Python中多線程與多進程對比的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

介休市| 白城市| 革吉县| 子洲县| 石柱| 开鲁县| 新平| 南岸区| 临城县| 孝昌县| 惠东县| 水富县| 灯塔市| 谷城县| 枣阳市| 定边县| 邢台县| 库伦旗| 页游| 昆山市| 襄城县| 无为县| 杨浦区| 滦南县| 彰化县| 龙川县| 沭阳县| 黄骅市| 遵义县| 长兴县| 山西省| 贵阳市| 鸡泽县| 常德市| 西和县| 望江县| 水城县| 台湾省| 济宁市| 太白县| 朔州市|