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

  • 已缴纳车船税的车船在同一年度
  • 视同销售的增值税怎么申报
  • 股东借款转实收资本需要什么原始凭证
  • 纳税人等级怎么划分
  • 房地产开发企业土地增值税清算
  • 固定收益款可以开增值税专票吗?
  • 土地增值税多交了怎么处理
  • 跨省工程需要什么条件
  • 制造费用包括哪三类
  • 个人债务转成股份
  • 企业购进货物暂估入库的会计分录如何处理?
  • 不动产折旧费计算公式
  • 支付短期借款计入什么科目
  • 预缴土地增值税需要计提吗
  • 月工资和账户工资区别
  • 一个季度为纳税期限的规定适用
  • 收到镇级财政扶持怎么办
  • 出售废品收入
  • 如何从零开始制作地下偶像
  • 解决网卡驱动故障的方法
  • ajax+json
  • php扩展编写
  • win10图片密码怎么全屏显示
  • 默认网关不可用win7
  • 鸿蒙系统怎么开启OTG
  • 预收账款为什么不属于金融负债
  • 非合理损耗会计分录
  • 资金性质是什么有哪些方面
  • 雷尼尔山位于美国西北部
  • 如何知道是干皮还是油皮
  • 兰萨罗特岛的地理位置
  • 预收账款增值税纳税义务
  • 浏览器同源策略限制
  • 餐饮专用发票可抵扣吗
  • 中小型科技企业所面临的普遍问题是资金缺乏
  • 开票软件是什么名字
  • 微信转账和支付宝转账的区别
  • 企业送的购物卡怎么退回去
  • 高效快速编制会计分录如何做?
  • 固定资产入账是税前还是税后
  • mysql联合索引使用规则
  • 财务应付
  • 其他应收款是如何核算的
  • 新办企业装修会计分录
  • 投资性房地产的后续计量
  • 使用SQL server创建数据库和表
  • 个人独资企业法主要内容
  • 车船税手续费返还时间
  • 物流辅助服务包含哪些内容
  • 出口退税项目
  • 残次品销售计入什么科目
  • 企业如何建账做账
  • sqlserver通用的删除服务器上的所有相同后缀的临时表
  • macbook appstore在哪
  • sendmailadmin
  • ias.exe是什么程序
  • centos elk
  • suse配置网络
  • win7系统怎样
  • 电脑安装win8系统
  • 方便存储 Win8系统的SkyDrive功能大体验
  • linux批量ping
  • android界面切换与数据传递
  • u3d手游开发
  • 高通平台工具下载
  • android查询数据库
  • list在python中的作用
  • js正则表达式写法
  • js获取form表单数据并显示
  • android 开发 教程
  • JavaScript中的方法名不区分大小写
  • python文本文件操作步骤
  • windows搭建python运行环境
  • 哪个机场离东莞樟木头最近
  • 买药开税票多少税率
  • 国家税务局总局官网
  • 上海地方税务局发票查询
  • 税务文书有哪些
  • 税务稽查立案标准金额
  • 如何进行税务筹划工作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设