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

  • 城市配套费的用途
  • 2023年印花税如何计算
  • 金税四期对个人所得税的影响
  • 场地使用费入什么科目
  • 当前时间该属期不可申报
  • 股东公司
  • 公司承担的社保可以税前扣除吗
  • 小企业会计准则会计科目表
  • 房地产股权收购案例
  • 接受捐赠计入什么费用
  • 政府补助的核算方法名词解释
  • 公司收到股东的钱现金流量表怎么填
  • 广告位租赁合同要交印花税吗
  • 运输发票抵税多少个点
  • etc发票进项抵扣的最新政策
  • 一个公司可以有几个公章
  • 财产保险费发票税率
  • 建筑业营改增实施指南
  • 关于个人所得税下列说法正确的是
  • 代扣代缴境外增值税可以抵扣
  • 一般纳税人专票和普票有什么区别
  • 报销车费怎么贴
  • 发票已认证但是没申报跨年度了怎么办
  • 用友t3新账套总账设置
  • win10更新21h1后很卡
  • 直接人工分配按计时工资怎么分
  • 携税宝费用可以抵扣增值税吗
  • 付不出去的应付账款要交增值税吗
  • 现金折扣的会计处理方法
  • 固定资产前期费用计入
  • 藏红花 (© Hayami Yanagisawa/Getty Images)
  • php动态网站开发项目教程
  • 自营 代理
  • PHP:imagecreatefromwbmp()的用法_GD库图像处理函数
  • 辅导期纳税人注意事项
  • 债务重组收益的计算
  • 企业应该从哪些方面把握消费者行为的关键点
  • 高新技术企业研发费比例
  • 企业支付宝账单明细怎么查
  • php如何获取当前时间
  • 主营业务收入借贷方向
  • vue解决异步取值问题
  • 芝麻信用app
  • 管理费用未分配利润
  • 不得抵扣增值税的情形有哪些
  • 客户的赔偿金会计分录
  • echarts怎么引入
  • 文化传媒有限公司英文
  • 企业主营业务收入净额怎么算
  • 福利费超过多少交税
  • 非居民企业的所得一律适用20%的企业所得税税率
  • 公司名下汽车过户个人需要补税吗
  • 防伪税控开票系统SOAP服务端
  • 融资租入固定资产的账务处理
  • 工会活动支出如何记账
  • 营业收入和销售收入的比值
  • 工业企业自制半导体材料
  • IPad怎么连接电视机看看影视
  • win8怎么分配磁盘空间
  • explorer.exe进程文件
  • 影响电脑速度的因素
  • 开机密码忘记了怎么打开手机
  • win10升级20h
  • win10周年版
  • win8桌面在c盘的路径
  • UNITY 4.6.2 IOS 64-BIT SUPPORT
  • js方法
  • nodejs requirejs
  • shell基础教程
  • 批量创建用户
  • js原生dialog
  • javascript向flash swf文件传递参数值注意细节
  • javascript高级程序设计电子书
  • 类似愤怒小鸟的小游戏
  • 基于unity3d
  • javascript入门基础
  • JavaScript中的数据类型分为两大类
  • python中lxml模块
  • android的中文
  • 叉车需要手续吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设