第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

運行多個代碼比運行一個代碼更快嗎?

運行多個代碼比運行一個代碼更快嗎?

胡子哥哥 2024-01-15 15:36:19
我的問題相當簡單:如果我有一段代碼,其中有一個迭代 150 次的 for 循環(huán)。將其分成 3 個文件,每個文件循環(huán)迭代 50 次是不是更快?如果是這樣,我是同時運行 3 個代碼還是一次運行一個?另一種選擇可能是multiprocessing在這 3 個文件中使用 python,但出現(xiàn)了同樣的問題,我是一次性運行它們還是一次運行一個?
查看完整描述

1 回答

?
白衣非少年

TA貢獻1155條經(jīng)驗 獲得超0個贊

這取決于。

在 cpython 中,全局解釋器鎖 (GIL) 確保給定進程中一次只有 1 個線程可以運行 python 代碼。如果您的循環(huán)受 CPU 限制,則在單個進程中添加線程不會加快速度。如果您的循環(huán)由于某種原因(例如從磁盤讀取數(shù)據(jù))而休眠,線程可以加速它。使用多處理,由于 GIL 是針對每個進程的,因此您可以加快處理速度。

多線程和多處理存在開銷,包括啟動線程/進程、向線程/進程獲取數(shù)據(jù)以及返回結果的成本。根據(jù)您所做的事情,這可能比循環(huán)本身更昂貴。

因此,這個問題沒有通用的答案。它高度依賴于任務。


查看完整回答
反對 回復 2024-01-15
  • 1 回答
  • 0 關注
  • 141 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號