位置: IT常识 - 正文

Python中的多进程是什么(python的多进程模块)

编辑:rootadmin

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

文章相关热门搜索词:python3 多进程,python 多进程,python的多进程效率低,python的多进程和多线程,python的多进程效率低,python的多进程效率低,python的多进程和多线程,python的多进程模块,内容如对您有帮助,希望把文章链接给更多的朋友!

多进程 multiprocessing

由于Python是跨平台的,自然也应该提供一个跨平台的多进程支持。multiprocessing模块就是跨平台版本的多进程模块。

multiprocessing模块提供了一个Process类来代表一个进程对象。

Unix/Linux操作系统提供了一个fork()系统调用,它非常特殊。普通的函数调用,调用一次,返回一次,但是fork()调用一次,返回两次,因为操作系统自动把当前进程(称为父进程)复制了一份(称为子进程),然后,分别在父进程和子进程内返回。

Python中的多进程是什么(python的多进程模块)

子进程永远返回0,而父进程返回子进程的ID。这样做的理由是,一个父进程可以fork出很多子进程,所以,父进程要记下每个子进程的ID,而子进程只需要调用getppid()就可以拿到父进程的ID。

Python的os模块封装了常见的系统调用,其中就包括fork,可以在Python程序中轻松创建子进程:

importosprint('Process(%s)start...'%os.getpid())#OnlyworksonUnix/Linux/Mac:pid=os.fork()ifpid==0:print('Iamchildprocess(%s)andmyparentis%s.'%(os.getpid(),os.getppid()))else:print('I(%s)justcreatedachildprocess(%s).'%(os.getpid(),pid))

运行结果如下:

Process(69673)start...I(69673)justcreatedachildProcess(69674)Iamchildproces(69674)andmyparentis69673.

有了fork调用,一个进程在接到新任务时就可以复制出一个子进程来处理新任务,常见的Apache服务器就是由父进程监听端口,每当有新的http请求时,就fork出子进程来处理新的http请求。

但是这个fork在windows操作系统是没有的。于是出现了处理fork的通用模块,以保证在不同操作系统间的调用。

multiprocessing模块就是跨平台版本的多进程模块。

multiprocessing模块提供了一个Process类来代表一个进程对象,下面的例子演示了启动一个子进程并等待其结束:

#!/usr/bin/envpython#coding=utf-8frommultiprocessingimportProcessimportos"""子进程要执行的代码"""defrun_proc(name):print('Runchildprocess%s(%s)'%(name,os.getpid()))if__name__=='__main__':print('Parentprocess%s.'%os.getpid())p=Process(target=run_proc,args=('test_code',))print('Childprocesswillstart.')p.start()p.join()print('Childprocessend.')

执行结果如下:

$pythonforkbymutilprocessing.pyParentprocess70227.Childprocesswillstart.Runchildprocesstest_code(70228)Childprocessend.

创建子进程时,只需要传入一个执行函数和函数的参数,创建一个Process实例,用start()方法启动,这样创建进程比fork()还要简单。

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

上一篇:python如何对多个CSV文件进行读取(python replace 多个)

下一篇:使用Element时默认勾选表格toggleRowSelection方式(element remove)

  • 跨区域涉税事项报验是什么意思
  • 含税销售额换算成不含税销售额的公式是什么?
  • 扫码开票开错了怎么改
  • 收入费用表本期盈余和资产负债表本期盈余
  • 法人私户转公户怎么操作
  • 普票能抵扣多少
  • 业务招待费进项税
  • 房地产企业被收购报表处理
  • 优惠办法
  • 对外销售产品
  • 企业所得税弥补亏损明细表怎么填写
  • 退税详细教程
  • 所得税费用为负数需要体现在报表上吗
  • 改变使用用途 规划处罚
  • 小规模纳税人未开票收入如何做账
  • 异地开票需要在当地交税吗
  • 研发废料收入实务中如何冲减研发费用?
  • 计提本月工资记账凭证怎么填
  • 车辆处置入账价值包括哪些
  • 事业单位的增值税科目
  • 个税累计预缴税额税率表是年还是月
  • 会计利润和税务利润的暂时性差异和永久性差异
  • 公司开一般户弊端
  • 跨区域个人所得税延期情况说明
  • 银行扣的短信费银行给开发票吗
  • 赠与房产再出售税费
  • 商业承兑到期兑不出来多久的追诉期
  • Realtek高清晰音频管理器设置方法
  • 戴尔r710服务器系统安装详解
  • 存货对外销售会计分录
  • linux如何安装
  • 收购自然人股东的股权要注意什么
  • 卖废旧物品账务处理
  • linux系统情况
  • 服务器数据迁移到新的服务器
  • 每季度预缴所得税怎么算
  • 不动产租赁费计入什么科目
  • 资产评估增值额
  • 前端架构怎么搭建
  • php课堂笔记
  • PHP:escapeshellcmd()的用法_命令行函数
  • 个人转让门面的法律规定
  • 企业常见的筹资方式有几种
  • html怎么做
  • 税务申报说明怎么写范文
  • vue路由详解
  • 常用php数组排序方法
  • php查询数据是否存在
  • 长期挂账的"其他应收款"该怎么处置
  • 计提的费用收到增值税专票
  • sql server备份数据还原不了怎么办
  • 二级栏目怎么做
  • 外经证开错作废要带些什么
  • 资产负债表固定资产清理
  • 小规模纳税人三减一政策
  • 国际货运代理企业不得从事的业务是
  • 银行本票与银行汇票的区别之一是
  • 会计估计变更和政策变更有哪些
  • 期初金额是什么
  • 工会经费网上怎么申报
  • 预收账款年底是不是不能有余额
  • 以前的房产证现在能过户吗
  • 成本费用占营业收入比重
  • 年初建账考虑要点有哪些
  • 序时账是明细账吗
  • Ubuntu 14.04/14.10如何安装记账软件HomeBank?
  • vmmem进程是什么
  • linux 文件查看
  • Win10 UWP红石版应用商店迎来更新:查找更新再换位置
  • linux中su切换用户不成功
  • win10开始菜单样式
  • bat批处理命令教程
  • jquery滚动到底部
  • awk入门
  • javascript的promise
  • javascript概述及作用
  • node服务器部署
  • git 删除分支和回滚的实例详解
  • 发票扫码抽奖用什么软件
  • 2021年税务高雅春联带横批
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设