主进程中等待进程池中所有任务都执行完毕

code
from multiprocessing import Pool
import time,random,os
 
def work(n):
    time.sleep(1)
    return n**2
if __name__ == '__main__':
    p=Pool()
 
    res_l=[]
    for i in range(10):
        res=p.apply_async(work,args=(i,))
        res_l.append(res)
 
    p.close()
    p.join() #等待进程池中所有进程执行完毕
 
    nums=[]
    for res in res_l:
        nums.append(res.get()) #拿到所有结果
    print(nums) #主进程拿到所有的处理结果,可以在主进程中进行统一进行处理
Outputs
macname@MacdeMacBook-Pro py % python3 cccccc.py
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
macname@MacdeMacBook-Pro py % 

 

 
 
 
 
 
 
 
 
 
 
 

posted @ 2020-12-26 17:20  anobscureretreat  阅读(256)  评论(0编辑  收藏  举报