等待所有python进程完成

Kre*_*der 3 python python-2.7 python-multiprocessing

我正在启动几个python进程,在循环中下载调用这段代码:

startTimeMillis = int(round(time.time() * 1000))

for i in range(10):
        p = multiprocessing.Process(target=performCurl, args =("http://www.google.com/d", i, ))
        p.start()


endTimeMillis = int(round(time.time() * 1000))
totalTimeSeconds = (endTimeMillis - startTimeMillis)
print "The whole process took ", str(totalTimeSeconds)
Run Code Online (Sandbox Code Playgroud)

我想检查所有进程完成所需的时间,那么如何让代码的最后一部分等待所有进程?

Tho*_*mas 9

使用p.join()等待进程终止

all_processes = [multiprocessing.Process(...) for ... in ...]
for p in all_processes:
  p.start()

for p in all_processes:
  p.join()
Run Code Online (Sandbox Code Playgroud)