位置: 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())

  • 运输费劳务是否可以扣除
  • 出售固定资产简易计税账务处理
  • 实收资本增加印花税税目
  • 付了电费当月没有收到发票
  • 收到的货品与实体不符
  • 公司牌车还款从哪里扣款
  • 事业单位需要写自传吗
  • 2018年出口退税税率
  • 停车费属于不动产租赁服务税率
  • 进项发票里的印花税如何做账?
  • 物资包括材料吗
  • 走物流的货物如何收费
  • 库存现金可以做中转科目嘛为什么
  • 计提减值的固定资产处置
  • 支付境外关联方借款利息需要的
  • 生产性生物资产是什么意思
  • 注册资本认缴与注册登记实操
  • windows7远程桌面连接在哪里
  • 会计准则和会计法的关系
  • 稿酬计入工资所得吗
  • 摊余成本计入哪个科目
  • 怎样选好布艺沙发
  • 个人股份转让
  • jmcacdefg什么意思
  • 公司每年都有什么费用
  • phpstudy怎么配置php环境
  • laravel入门与实战
  • 待处理财产损益借贷方向
  • phpwechat
  • html5旅游网页设计
  • 预付采购材料款60000元
  • 固定资产毁损应该填制什么凭证
  • 如何一次性删除微信账单记录
  • 应交税费的期末余额在借方表示什么
  • wordpress site
  • 前年度多交附加税怎么交
  • 员工手机补助单怎么做账
  • mysql 使用索引
  • 长期股权投资处置损失计入什么科目
  • 个人所得税又是什么税种
  • 清包工方式建筑服务
  • 原始凭证在账务处理程序中的作用
  • 增值税报表附表三
  • 个人所得税专项扣除2023最新政策
  • 政府奖励金怎么发放
  • 两种原因
  • 医生规培补助
  • 货物逾期保管费怎么算
  • 稳岗返还计入营业外收入
  • 法人投资属于什么会计科目
  • 记账金额错误
  • 税务入账的加油费怎么算
  • 发生额大额标准怎么确定
  • 开餐饮店需要什么条件才能开
  • 对公提现是什么意思啊
  • 企业会计准则第4号固定资产
  • 发票金额大于付款金额可以报销吗
  • mysql的基本介绍
  • windows7软件运行没反应
  • win8.1补丁包
  • 查看linux系统版本信息
  • 如何清理注册表文件
  • win7麦克风没声音怎么设置方法从计算机
  • macbook air一键恢复出厂设置
  • 双系统计算机怎么开机
  • ubuntu 电子书
  • 照相机文件名
  • linux系统开发环境
  • win10系统打不开网页怎么办
  • nodejs查找文件
  • unity如何成一组
  • unity怎么导入材质包
  • jquery 弹出页面
  • python模块怎么用
  • 修复硬盘
  • 车辆购置税是国税吗
  • 期房交了契税就可以拿房产证了吗
  • 税务全国联网了吗
  • 美国企业所得税税率2022
  • 税务局直属机构
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设