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

  • 个人独资企业是有限责任还是无限责任
  • 用友t3怎么结转本年利润
  • 银行转账支付计入什么科目
  • 原始凭证分割单样本
  • 印花税多报了几块钱税务局会找我吗
  • 春节商家促销文案
  • 股票卖出印花税费率
  • 固定资产被盗报警
  • 劳务报酬所得是什么
  • 关于半年度净资产的公告
  • 年会费用的会计分录
  • 收到小微企业补贴如何做账
  • 6位数开票代码
  • 小微企业销售已按固定资产入账的办公家具也享受免税政策吗?
  • 15-算
  • 2人注册的公司换一个人怎么办
  • 工资薪金中的误餐补助,征收个人所得税
  • 净资产是所有者权益一样吗
  • 交通票报销有哪些
  • 纳税能力体现的内容
  • 固定资产拆除后账务处理
  • 商铺土地增值税清算
  • 公司账户里的钱有利息吗
  • Mac如何开启无痕浏览
  • 小规模年底税金怎么算
  • 关税从量计征有什么
  • linux mount命令详解
  • 本年利润和未分配利润怎么结转
  • 凭证包括几个部分
  • 如何通过手机号码查对方在哪里
  • 财产清查两种制度
  • 公司网站维护费用计哪个科目
  • php递归实现1到100的和
  • 税控机维护费抵扣分录
  • 申请个人所得税
  • 软件开发属于技术合同吗
  • 城建税5%的是什么情况
  • 项目折现率计算公式
  • 车船税为什么没有发票
  • Python函数怎么返回
  • mongodb主备
  • 投资公司和控股公司关系
  • 差额增收企业怎么做账
  • 哪几种进项税额允许抵扣
  • 火车票丢了怎么办
  • 对方多开票账务会怎么样
  • 企业取得的财政性资金
  • 外经证预缴税款必须去外地交税吗
  • 固定资产报废会议纪要模板
  • 开具的增值税专用发票上注明的价款含税吗
  • 托盘费用怎么核算
  • 每个银行都有结息
  • 研发费用扣除75%
  • 连锁药店之间调拨药品
  • 盈余公积金计算方法
  • 会计总监的薪资是多少
  • 看过有趣的童话书,简单介绍下
  • 最全的sql执行顺序
  • 自动备份mssql server数据库并压缩的批处理脚本
  • macossierra安装发生错误
  • windows xp操作
  • centos 查看服务
  • WeatherEye.exe - WeatherEye 是什么进程
  • winxp系统介绍
  • win10 20h2官方下载
  • win8怎么一开机就进入桌面
  • win8蓝牙连不上
  • 为什么没有win8系统
  • windows10移动
  • ant压缩包删除
  • 使用jquery实现的项目
  • centos6安装python
  • python元数据
  • node发送邮箱
  • 浅谈幼儿良好行为的培养论文
  • 安卓接口分类
  • JavaScript fontcolor方法入门实例(按照指定的颜色来显示字符串)
  • 税盘上怎么查每个月一共开了多少金额
  • 有机肥料销售是做什么的
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设