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

  • 个人独资企业需要报税吗
  • 土地增值税的计算方法公式
  • 城镇土地使用税的计算公式
  • 资产处置损益和固定资产清理的区别
  • 联营企业属于企业吗
  • 快递费专票可以报销吗
  • 怎样查是否为一类银行卡
  • 跨年度费用报销违反什么规定
  • 企业所得税查增值税吗
  • 成品油进项税转出
  • 银行承兑汇票收费标准
  • 用于在建工程的贷款利息
  • 拆迁补偿款上交财政
  • 流动性比率小于3说明什么
  • 纳税调整税收金额
  • 增值税发票过期了税金怎么办
  • 母公司收购少数股东股权,之前的利润母公司不享有
  • 小微企业季度缴税一百万退税吗
  • 美国税改“梦想”很丰满,显示很骨感
  • 银行理财产品属于基金吗
  • 租赁服务可以享受加计抵减吗
  • 资产置换税务处理案例
  • 企业从境外收回所得税
  • 设备维修费增值税
  • 国家统计局一套表平台网址
  • 汇算清缴所得税补缴怎么处理
  • 中秋福利费会计分录
  • ’sass_binary_site‘ is not a valid npm option问题的产生原因及解决办法
  • 如何通过u盘重启
  • 图书装订的工作容易吗
  • 微软win11预览版
  • 缴纳公积金需要什么
  • 工程施工与工程结算在资产负债表里
  • 小规模纳税人需要缴纳个人所得税吗
  • php最好的教程
  • 应收债权与应付债务
  • 框架的弊端和作用
  • 预缴土地增值税的税率
  • 民办非企业单位登记管理暂行条例
  • vue中使用require报错
  • 只有进项税没有销项
  • vue中created和mounted
  • 前端底层架构是什么意思
  • 未分配利润的核算内容
  • 纳什理论是什么
  • 申报经营所得成绩怎么填
  • Sqlite数据库里插入数据的条数上限是500
  • sqlserver2008安装完在哪打开
  • 公司购买的金蝶软件属于的固定资产吗
  • 物业公司购买空调合法吗
  • 产品的质量监督部门是指
  • 应付票据是
  • 应收账款和应付账款的管理
  • 低值易耗品的金额
  • 租赁房屋取得发票怎么开
  • 车辆保险费算什么费用
  • 纳税人财务核算内容包括
  • 国税地税合并的时间
  • 企业预付账款怎么做账
  • 商业零售企业商品进销差价
  • MySQL数据库同时查询更新同一张表的方法
  • mysql使用命令
  • sql基本教程
  • ubuntu怎么安装包
  • driver's
  • camrec是什么文件
  • 双显示器设置主副屏的方法
  • pssvc.exe - pssvc是什么进程 有什么用
  • win8无法使用内置管理员账户打开ie
  • Android触摸事件回调方法
  • linux监控程序
  • cmd的tree指令
  • js中的flat
  • activate webstorm
  • 广州地税局官网办事点
  • 个税已申报税额为0可以退税吗
  • 岗位回避什么意思
  • 浙江省工伤停工留薪期分类目录
  • 贵州国家税务局陈开平
  • 车辆免征信息怎么查
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设