大家有没有考虑过可以直接用进程池去做任务呢?我们习惯性自己去处理一个任务,但是比较麻烦,如果可以制作一个进程自己去处理能实现吗?答案一定是肯定的,但是需要借助apply功能,大家知道要这个方法吗?知道怎么去使用吗?如果不了解的话,可以继续看下文了哦~
成都创新互联公司专注于企业成都全网营销推广、网站重做改版、左云网站定制设计、自适应品牌网站建设、H5建站、商城网站开发、集团公司官网建设、成都外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为左云等各大城市提供网站开发制作服务。
apply_async与apply区别:
l apply:添加任务后,等待进程函数执行完,
l apply_async:添加任务后,立即返回,支持回调;原型如下:
#callback为回调函数 pools.apply_async(func, args=(), kwds={}, callback=None, error_callback=None,)
直接看例子:
from multiprocessing import Pool import time import os def func(*args, **kwargs): # 定义进程函数 print('sub process id:', os.getpid()) time.sleep(1) if __name__ == "__main__": start = time.time() # 创建进程池,进程数为4 pools = Pool(4) for i in range(5): # 添加任务 pools.apply_async(func) # 关闭进程池,不在添加任务 pools.close() pools.join() print("cost time:", int(time.time()-start))
结果:
sub process id: 15536 sub process id: 2788 sub process id: 20288 sub process id: 11020 sub process id: 15536 cost time: 2
现在大家应该知道怎么去使用apply这个方法了吧,害怕大家不清楚明白,还给大家准备了一个示例,大家可以看下示例演示,也可以很容易理解的哦~
新闻标题:创新互联Python教程:python进程池中apply如何使用?
分享URL:http://www.csdahua.cn/qtweb/news34/544334.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网