时间:2020-07-30 python教程 查看: 814
本文实例讲述了Python多进程multiprocessing、进程池用法。分享给大家供大家参考,具体如下:
multiprocessing:
进程池:
python中的多进程需要使用multiprocessing模块
1.进程的创建:进程对象=multiprocessing.Process(target=函数名,args=(参数,))【补充,由于args是一个元组,单个参数时要加“,”】
2.进程的运行: 进程对象.start()
进程的join跟线程的join一样,意义是 “阻塞当前进程,直到调用join方法的那个进程执行完,再继续执行当前进程”
注:在windows中代码中必须使用这个
import multiprocessing,time,os
def thread_run():
print(threading.current_thread())
def run(name):
time.sleep(1)
print("hello",name,"run in ",os.getpid(),"ppid:",os.getppid())
if __name__=='__main__':#必须加
obj=[]
for i in range(10):
p=multiprocessing.Process(target=run,args=('bob',))
obj.append(p)
p.start()
start_time=time.time()
for i in obj:
i.join()
print("run in main")
print("spend time :",time.time()-start_time)
继承multiprocessing的Process类的类要主要做两件事:
1.如果初始化自己的变量,则先要调用父类的__init__()【如果不调用,则要自己填写相关的参数,麻烦!】然后做自己的初始化;如果不需要初始化自己的变量,那么不需要重写__init__,直接使用父类的__init__即可【已经继承了】
2.重写run函数
import multiprocessing
class myProcess(multiprocessing.Process):
def run(self):
print("run in myProcess")
if __name__=="__main__":
p=myProcess()
p.start()
p.join()
from multiprocessing import Pool
import time,os
def func1(i):
time.sleep(1)
print("run in process:",os.getpid())
if __name__=="__main__":
pool=Pool(5)
start_time = time.time()
for i in range(10):
pool.apply(func=func1,args=(i,))#串行,这里是加一个运行完再加一个
pool.close()#先close再等待
pool.join()
print("main run done,spend_time:",time.time()-start_time)
from multiprocessing import Pool
import time,os
def func1(i):
time.sleep(1)
print("run in process:",os.getpid())
if __name__=="__main__":
pool=Pool(5)
start_time = time.time()
for i in range(10):
pool.apply_async(func=func1,args=(i,))#并行
pool.close()#先close再等待
pool.join()
print("main run done,spend_time:",time.time()-start_time)#2.6,证明是并行
from multiprocessing import Pool
import time,os
def func1(i):
time.sleep(1)
print("run in process:",os.getpid())
return "filename"
def log(arg):##参数为进程创建中func的函数的返回值
print("log done :",arg)
if __name__=="__main__":
pool=Pool(5)
start_time = time.time()
for i in range(10):
pool.apply_async(func=func1,args=(i,),callback=log,)#log的参数是func1的返回值
pool.close()#先close再等待
pool.join()
print("main run done,spend_time:",time.time()-start_time)
Pool
对象调用join()
方法会等待所有子进程执行完毕,调用join()
之前必须先调用close()
,调用close()
之后就不能继续添加新的Process
了。【意思就是比如游泳池只卖1个小时的票,约定5点关门,那么4点多之后就不能再卖票了,就一直等着游泳池里面的人出来再关门,进程池的close是一个关门的意思,并不是结束的意思,它只是关上了进来的门,而里面的进程还可以运行】【进程池的join是等池子里的所有进程执行完毕,如果后面再进来进程的话就没完没了了,所以需要先关闭进入,再等待进程结束】
希望本文所述对大家Python程序设计有所帮助。