from multiprocessing import Pool
import time,random
def worker(msg):
start=time.time()
print('%s----开始执行'%msg)
time.sleep(random.random())#模拟工作消耗的时间
end=time.time()
print('%s--执行完毕,消耗时间:%0.2f'%(msg,end-start))
if __name__ == '__main__':
p=Pool(3)#创建容量是三的进程池
for i in range(10):
#将进程添加到进程池
#格式:进程池apply_astnc(fuce=单个进程要调用的目标,args=(参数1,参数2.。。)
#每次循环将会用空闲的子进程去调用目标
p.apply_async(func=worker,args=(i,))
#关闭后,进程池不再接受新的任务
print('--------start--------')
p.close()
#等待进程池中所有子进程运行结束后,注意,join放在close后面
p.join()
print('------------end------------')
进程池
最新推荐文章于 2024-07-04 20:48:15 发布