簡體   English   中英

Python 代碼使用多進程無限運行

[英]Python code using multiprocessing running infinitely

我正在嘗試使用多處理在 jupyter notebook 中執行以下代碼,但循環無限運行。
我需要幫助解決這個問題。

import multiprocessing as mp
import numpy as np

def square(x):
    return np.square(x)

x = np.arange(64)

pool = mp.Pool(4)
squared = pool.map(square, [x[16*i:16*i+16] for i in range(4)])

mp.cpu_count()的 output 是 4。

您需要將代碼重寫為:

def main():
    x = np.arange(64)
    pool = mp.Pool(4)
    squared = .....

if __name__ == '__main__':
    main()

此代碼當前正在每個進程中運行。 您需要它只在執行設置的一個進程中運行。

你忘了:

pool.close()
pool.join()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM