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

  • 苹果13密码怎么设置四位(苹果13密码怎么解开)

    苹果13密码怎么设置四位(苹果13密码怎么解开)

  • 淘宝特价版是阿里巴巴旗下的吗(淘宝特价版也是阿里巴巴的吗)

    淘宝特价版是阿里巴巴旗下的吗(淘宝特价版也是阿里巴巴的吗)

  • 电脑如何更改用户名字(电脑如何更改用户文件名)

    电脑如何更改用户名字(电脑如何更改用户文件名)

  • 如何共享文件(不同网络的电脑如何共享文件)

    如何共享文件(不同网络的电脑如何共享文件)

  • cdr文件打不开怎么办(cdr打开不了怎么办)

    cdr文件打不开怎么办(cdr打开不了怎么办)

  • 电脑换屏对电脑有影响吗(电脑换屏幕会有什么影响)

    电脑换屏对电脑有影响吗(电脑换屏幕会有什么影响)

  • kirin是啥处理器(kirin系列处理器)

    kirin是啥处理器(kirin系列处理器)

  • 苹果11微信怎么变成黑色(苹果11微信怎么截长屏截图)

    苹果11微信怎么变成黑色(苹果11微信怎么截长屏截图)

  • mm xlog文件可以删除吗(xlog文件用什么打开)

    mm xlog文件可以删除吗(xlog文件用什么打开)

  • 微信分身要不要重新注册账号

    微信分身要不要重新注册账号

  • 手机整夜充电有伤害吗(手机整夜充电有影响吗)

    手机整夜充电有伤害吗(手机整夜充电有影响吗)

  • 听筒坏了是什么症状(听筒坏了自己能修复)

    听筒坏了是什么症状(听筒坏了自己能修复)

  • 苹果刷公交卡需要打开钱包吗(苹果刷公交卡需要按两下)

    苹果刷公交卡需要打开钱包吗(苹果刷公交卡需要按两下)

  • 电脑上的复制键是哪个(电脑上复制粘贴按什么键)

    电脑上的复制键是哪个(电脑上复制粘贴按什么键)

  • 淘宝默认好评是啥意思(淘宝默认好评是全5分吗)

    淘宝默认好评是啥意思(淘宝默认好评是全5分吗)

  • 耳机l是左还是右(耳机l是左还是R是左)

    耳机l是左还是右(耳机l是左还是R是左)

  • 半开麦和全开麦是什么意思(半开麦和全开麦哪个好听)

    半开麦和全开麦是什么意思(半开麦和全开麦哪个好听)

  • qq自动发广告怎么回事(qq老自动发布广告)

    qq自动发广告怎么回事(qq老自动发布广告)

  • 淘宝店铺为什么被关闭了(淘宝店铺为什么搜索店名搜索不到)

    淘宝店铺为什么被关闭了(淘宝店铺为什么搜索店名搜索不到)

  • 京东评价记录怎么删除(京东评价记录在哪)

    京东评价记录怎么删除(京东评价记录在哪)

  • vue怎么调照片呈现速度(vue怎么照片设置)

    vue怎么调照片呈现速度(vue怎么照片设置)

  • 华为mate30是5g手机么(华为MATE30是5G手机吗)

    华为mate30是5g手机么(华为MATE30是5G手机吗)

  • 手机在线2g代表什么(手机在线2g代表了什么)

    手机在线2g代表什么(手机在线2g代表了什么)

  • 荣耀手环3怎么强制关机(荣耀手环3怎么连接手机)

    荣耀手环3怎么强制关机(荣耀手环3怎么连接手机)

  • ios13怎样开启黑夜模式(ios13黑暗模式怎么开)

    ios13怎样开启黑夜模式(ios13黑暗模式怎么开)

  • 喵赞提现失败怎么办(喵赞是真的吗)

    喵赞提现失败怎么办(喵赞是真的吗)

  • 充电最快的智能手机(2021充电最快)

    充电最快的智能手机(2021充电最快)

  • 有效的管理你的vim插件(有效的管理你的时间的重要性英文作文)

    有效的管理你的vim插件(有效的管理你的时间的重要性英文作文)

  • 个人所得税年终奖单独计税怎么操作
  • 个体工商户增值税优惠政策2023
  • 企业所得税汇算清缴退税怎么做账
  • 印花税的征税范围具体有哪些
  • 民办非企业所得税优惠政策
  • 一般纳税企业所得税税率是多少2019
  • 一般税收协定是多少
  • 两个公司发工资怎么交个税
  • 股权转让怎么申报
  • 用现金支付需要附哪些单据
  • 食品增值税专用发票可以退税吗?
  • 农产品增值税抵扣政策文件
  • 医院员工工资表模板
  • 一般纳税人转让二手车增值税税率
  • 年会奖金多少合适
  • 安家费要还吗
  • 农产品没有进项税怎么算
  • 提供物业管理服务的纳税人如何认定
  • 软件服务类企业
  • 高新技术企业所得税税率
  • 技术服务费发票需要备注吗
  • 销售不动产扣除项目有哪些
  • 减免税金需要结转吗
  • 企业所得税税率2.5% 5% 25%
  • 定额备用金制度
  • PHP:stream_get_wrappers()的用法_Stream函数
  • gradle视频教程
  • php运用的技术php开发有哪些实用的技术
  • yii2框架中文手册
  • 非关联企业借款利息扣除
  • php定义字符串的三种方式
  • 中途建账期初数据哪里来的
  • vue2路由跳转页面不刷新问题
  • 模型参数是什么意思
  • 生产企业出口退税账务处理会计分录
  • 对公帐户进出帐要交税吗
  • 金税盘报送汇总在哪
  • 自产自销免税农产品需要缴纳印花税吗
  • 债转股需要哪些资料
  • phpcms v9用户手册
  • 织梦相关文章调用
  • 工厂的污水处理站作用
  • 驱动开发:内核是什么
  • phpcms怎么样
  • 民办学校学费收现金
  • 应付利息增加说明企业什么
  • sql server s
  • 破产企业资产拍卖后,管理人仅办理产权登记未交付房屋
  • 一般纳税人销售旧货
  • 堤防维护费税率
  • 其他应付款属于哪类
  • 小规模可以开红网吗
  • 无形资产摊销怎么计算月摊销额
  • 金税三期网络设置
  • sql语句学习
  • c3p0连接池提供了哪些方式来配置连接池的参数
  • linux系统讲解
  • xp系统如何安装软件
  • linux中find命令基本使用方法
  • win10系统如何清洗打印机喷头
  • centos8 redhat
  • scards32.exe - scards32是什么进程 有什么用
  • 没有触屏如何使手机充电
  • 宽带连接找不到设备是怎么回事
  • cocos2dx 3.17
  • Coroutine couldn't be started because the the game object 'GameController' is inactive!
  • 示例代码
  • Android游戏开发实践指南
  • AngularJS中controller控制器继承的使用方法
  • jquery$符号
  • 从零开始学什么
  • android基础入门教程
  • jquery鼠标位置
  • 详解Javascript事件驱动编程
  • 各种建筑材料税率表
  • 宪法宣誓仪式流程图
  • 厦门税务地区编号
  • 地下建筑规定
  • 海南购房税费最新2019规定
  • 山西税务体检医院
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设