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

  • 业务招待费进项税
  • 企业存款利息收入税率
  • 固定资产认证进项在勾选平台勾吗
  • 原材料计划价实际价区别
  • 何为提租补贴
  • 17点增值税发票能开吗
  • 项目部管理人员及作业人员的
  • 个人投资收益要交所得税吗
  • 增值税专用发票有效期是多长时间
  • 上海个人住房房产税
  • 印花税税基含不含增值税
  • 小规模纳税人纳税申报时间
  • 建筑施工的会计科目
  • 企业个税网上申报时间
  • 转出未交增值税科目
  • 金税盘基本信息设置
  • 租房税收缴款书在哪里打印
  • 收到以前年度退回的企业所得税怎么做账
  • 大学期末 知乎
  • 抵押质押的含义
  • 笔记本cpu天梯图苹果
  • 简易征收的分录
  • steam怎么退款申请退款要多久
  • php字符串函数大全
  • 在php中,字符串有哪些表示形式
  • 已提折旧固定资产评估增值的会计处理是企业会计准则
  • g++.exe error
  • thinkphp5自定义标签
  • 银行存款转定期存款分录
  • vue方法顺序执行
  • 葡萄酒企业已纳税多少
  • linux搭建web服务器
  • php ascii
  • 残保金解决方案
  • 技术knowhow
  • uniapp自定义导航栏渐变
  • jasypt加密解密
  • php入门基础教程
  • 起征点适用于
  • lspv命令详解
  • 直接融资租赁案例
  • 文章列表是什么
  • 营改增一般纳税人简易征收的范围
  • 企业预收账款缴纳个税吗
  • 企业境外投资管理
  • 什么是小微企业
  • 建筑业外管证预审要多久
  • 分页存储的优缺点
  • 应付账款主要账户有哪些
  • 保教费免征增值税政策
  • 利润分享并购方法有哪些
  • 折旧和摊销的概念
  • 个人出租租房收什么税
  • 小规模纳税人所得税优惠政策2023
  • 科目怎么写?
  • 劳务费需要通过应付职工薪酬科目核算吗
  • 保险公司会计的特点
  • sqlserver获取uuid
  • ubuntu怎么安装包
  • 怎么检测u盘是否扩容
  • win8.1系统更新后启动不了
  • mac os10.11
  • ubuntu设置共享文件夹命令mount
  • centos8指令
  • 360se是什么文件夹
  • 微信付费使用是真的吗
  • winxp网络连接没有无线网络
  • win8 应用商店
  • windows累积更新失败怎么办
  • windows8.1怎么用
  • Cocos2d-x 3.x lua绑定
  • Windows下自动备份MongoDB的批处理脚本
  • k mean python
  • 原生js有用吗
  • js制作网站
  • ugui粒子ui层级
  • 游戏客服怎么跟客户聊天
  • jquery更换图片
  • 办理税控盘的流程
  • 企业税务代码是什么号
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设