位置: IT常识 - 正文

Python中的进程池是什么(python 进程管理)

编辑:rootadmin

推荐整理分享Python中的进程池是什么(python 进程管理),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python 进程池 队列,进程池 python,python进程池的作用,python进程池和线程池,python进程池的作用,进程 python,python3 进程池,进程 python,内容如对您有帮助,希望把文章链接给更多的朋友!

进程池Pool

当需要创建的子进程数量不多时,可以直接利用multiprocessing中的Process动态成生多个进程,但如果是上百甚至上千个目标,手动的去创建进程的工作量巨大,此时就可以用到multiprocessing模块提供的Pool方法。

初始化Pool时,可以指定一个进程数,当有新的请求提交到Pool中时,如果池还没有满,那么就会创建一个新的进程用来执行该请求;但如果池中的进程数已经达到指定的值,那么该请求就会等待,直到池中有进程结束,才会创建新的进程来执行。

frommultiprocessingimportPoolimportosimporttimeimportrandomdefworker(msg):t_start=time.time()print("%d进程开始执行%d"%(os.getpid(),msg))#random.random()随机生成0~1之间的浮点数time.sleep(random.random()*2)t_stop=time.time()print(msg,"执行完毕,耗时%0.2f"%(t_stop-t_start))if__name__=='__main__':po=Pool(3)#定义一个进程池,进程数3foriinrange(0,10):#Pool.apply_async(要调用的目标,(传递给目标的参数元祖,))#每次循环将会用空闲出来的子进程去调用目标po.apply_async(worker,(i,))print("----start----")po.close()#关闭进程池,关闭后po不再接收新的请求po.join()#等待po中所有子进程执行完成,必须放在close语句之后print("-----end-----")

运行结果为:

----start----4353进程开始执行04354进程开始执行14355进程开始执行22,执行完毕,耗时0.204355进程开始执行31,执行完毕,耗时1.194354进程开始执行44,执行完毕,耗时0.374354进程开始执行50,执行完毕,耗时1.574353进程开始执行65,执行完毕,耗时0.194354进程开始执行73,执行完毕,耗时1.634355进程开始执行86,执行完毕,耗时0.494353进程开始执行98,执行完毕,耗时0.757,执行完毕,耗时0.909,执行完毕,耗时0.63-----end-----

相关推荐:《Python视频教程》

Python中的进程池是什么(python 进程管理)

multiprocessing.Pool常用函数解析:

apply_async(func[, args[, kwds]]) :使用非阻塞方式调用func(并行执行,堵塞方式必须等待上一个进程退出才能执行下一个进程),args为传递给func的参数列表,kwds为传递给func的关键字参数列表;

apply(func[, args[, kwds]]):使用阻塞方式调用func

close():关闭Pool,使其不再接受新的任务;

terminate():不管任务是否完成,立即终止;

join():主进程阻塞,等待子进程的退出, 必须在close或terminate之后使用;

apply堵塞式

frommultiprocessingimportPoolimportosimporttimeimportrandomdefworker(msg):t_start=time.time()print("%d进程开始执行%d"%(os.getpid(),msg))#random.random()随机生成0~1之间的浮点数time.sleep(random.random()*2)t_stop=time.time()print(msg,"执行完毕,耗时%0.2f"%(t_stop-t_start))if__name__=='__main__':po=Pool(3)#定义一个进程池,进程数3foriinrange(0,10):#Pool.apply_async(要调用的目标,(传递给目标的参数元祖,))#每次循环将会用空闲出来的子进程去调用目标po.apply(worker,(i,))print("----start----")po.close()#关闭进程池,关闭后po不再接收新的请求po.join()#等待po中所有子进程执行完成,必须放在close语句之后print("-----end-----")

运行结果为:

4400进程开始执行00,执行完毕,耗时1.894401进程开始执行11,执行完毕,耗时1.914402进程开始执行22,执行完毕,耗时1.644400进程开始执行33,执行完毕,耗时1.164401进程开始执行44,执行完毕,耗时1.854402进程开始执行55,执行完毕,耗时0.294400进程开始执行66,执行完毕,耗时0.194401进程开始执行77,执行完毕,耗时1.194402进程开始执行88,执行完毕,耗时0.614400进程开始执行99,执行完毕,耗时1.08----start---------end-----

说明:通过运行结果可以看出来,阻塞式会等进程池中的进程都执行完毕了才会运行主进程的start和end的打印

相关推荐:

本文链接地址:https://www.jiuchutong.com/zhishi/310240.html 转载请保留说明!

上一篇:帝国cms怎么换模板(帝国cms移动端设置教程)

下一篇:php中__get如何获取成员属性(php __get())

  • 小规模纳税人升级一般纳税人流程
  • 如何理解增值税中性特点
  • 企业中征码全称
  • 物流公司主营业务范围
  • 小规模企业所得税多少
  • 外地企业如何在本地纳税
  • 企业所得税预缴计算方法
  • 支付宝怎么开个人增值税发票
  • 丢失发票罚款如何入账
  • 企业可以不弥补以前年度亏损吗
  • 交易或事项对会计等式的影响表格怎么填
  • 印花税算错了可以补交吗
  • 外商投资企业退出条件
  • 什么是成本核算你觉得成本核算重要吗为什么
  • 给企业供货都有哪些渠道
  • 核销贷款收回要冲减资产减值损失吗
  • 异地缴纳个人所得税
  • 企业进口应税物资在进口环节应交的消费税,应计入
  • 个体户到税务局开普票需要什么手续
  • 旅行社开具会议费发票可以差额征税吗
  • 高新技术企业优惠政策叠加
  • 发票代码和发票号码在一起怎么办
  • 投资款缴纳印花税税目是什么
  • 收到赔材料赔付款怎样做账?
  • 主机 bios
  • 吊销执照公司资产怎么办
  • 期初摊余成本是初始入账价值吗
  • 信用证保证金账户
  • 收到挂靠方应缴纳税款如何做账?
  • 苹果手机上传速度很慢
  • 如何控制网络速度
  • 计提本月所得税费会计分录
  • vue 自动部署
  • jsonobject忽略字段
  • vue项目引入ts
  • 前端解决跨域问题的8种方案(最新最全)
  • vscode+cmake
  • 成品油批发和零售许可
  • 报税扣款锁定怎么处理
  • 自制原始凭证代码怎么填
  • 增值税专用发票进项
  • 进项大于销项怎么做分录
  • 研发费用加计扣除2022政策
  • golang eventbus
  • mysql使用技巧
  • phpcms怎么用
  • 资产捐赠账务处理
  • 社保公司承担部分怎么做账
  • PostgreSQL教程(九):事物隔离介绍
  • 社保局退的工伤保险怎么记账
  • 结算备付金账户是什么帐户
  • 出纳现金日记账怎么记账
  • 运输途中丢失的物品赔偿
  • 专票三流合一指哪三流
  • 什么是企业合并?
  • 一个身份证可以实名几个qq
  • 工业企业固定资产投资
  • xp系统的本地连接
  • winxp内存不足怎么办
  • win7 win8.1
  • 利用图片密码登录微信
  • linux中vi编辑器怎么使用
  • linux主要充当什么样的服务角色
  • linux中如何修改文件内容
  • jquery的实现原理
  • 基于javascript的毕业设计
  • ecmascript6教程
  • android 像素
  • 使用时间
  • c#委托的理解
  • ca钥匙登陆不了电子税务局
  • 应税消费品通过什么科目核算
  • 公益性公墓免交税吗
  • 动车票电子发票如何获取
  • 柬埔寨现在的领导
  • 电子缴款凭证可以用于报销吗
  • 沙石开发票
  • 委托人全权代理
  • 2019小规模纳税人标准
  • 如果企业所得税没有做计提怎么办?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设