python创建进程的方法(Python多进程fork函数详解)
python创建进程的方法
Python多进程fork函数详解进程
进程是程序的一次动态执行过程,它对应了从代码加载、执行到执行完毕的一个完整过程。进程是系统进行资源分配和调度的一个独立单位。进程是由代码(堆栈段)、数据(数据段)、内核状态和一组寄存器组成。
在多任务操作系统中,通过运行多个进程来并发地执行多个任务。由于每个线程都是一个能独立执行自身指令的不同控制流,因此一个包含多个线程的进程也能够实现进程内多任务的并发执行。
进程是一个内核级的实体,进程结构的所有成分都在内核空间中,一个用户程序不能直接访问这些数据。
进程的状态:
创建、准备、运行、阻塞、结束。
进程间的通信方式可以有:
- 文件
- 管道
- socket
- 信号
- 信号量
- 共享内存
要让Python程序实现多进程(multiprocessing),必须先了解操作系统的相关知识。
在Unix/Linux操作系统提供了一个fork()函数,它非常特殊,调用一次,返回两次,因为操作系统将当前的进程(父进程)复制了一份(子进程),然后分别在父进程和子进程内返回。
Python中的进程
- os.fork()
- subprocess
- processing
- multiprocessing
fork()函数
函数原型:
|
Help on built - in function fork in module posix: fork(...) fork() - > pid Fork a child process. Return 0 to child process and PID of child to parent process. |
从fork()函数原型来看,它也属于一个内建函数。
子进程永远返回0,而父进程返回子进程的ID。这样做的理由是,一个父进程可以fork()出很多子进程,所以,父进程要记下每个子进程的ID,而子进程只需要调用getppid()就可以拿到父进程的ID。
Python的进程函数fork()是在os模块,下面是一个关于进程的例子:
|
import os print os.getpid() #获取子进程的进程号 pid = os.fork() if pid = = 0 : print 'I am child process (%s) and my parent is %s.' % (os.getpid(), os.getppid()) else : print 'I (%s) just created a child process (%s).' % (os.getpid(), pid) |
执行结果:
1526
I (1526) just created a child process (1527).
I am child process (1527) and my parent is 1526.
有了fork调用,一个进程在接到新的任务时,就可以复制出一个子进程来处理新任务。常见的Apache服务器就是由父进程监听端口,一旦有新的http请求时,就fork出子进程来处理新的http请求。
再看一个例子:
|
#coding=utf-8 import os os.fork() print 1 |
执行结果:
1
1
程序中,父进程中创建了一个子进程,子进程运行打印了一个1,回到父进程又打印了一个1,所以结果是打印了2个1。
需要注意的是,上面创建进程的函数都是Unix/Linux下的,Windows下是没有的,那在Windows下又使用什么实现多进程呢?
由于Python是跨平台的,自然也应该提供一个跨平台的多进程支持。multiprocessing模块就是跨平台版本的多进程模块, 支持子进程、通信和共享数据、执行不同形式的同步。
multiprocessing模块提供了一个Process类来创建一个新的进程对象。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对开心学习网的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://blog.csdn.net/SeeTheWorld518/article/details/49639247
- python实现层次遍历二叉树(Python实现的序列化和反序列化二叉树算法示例)
- python语言提供的3种基本数据类型(详解Python3 基本数据类型)
- python云服务技术(Python脚本修改阿里云的访问控制列表的方法)
- python中pip和pip3有什么区别(ISAPI-REWRITE伪静态规则写法以及说明)
- python读取txt文件每一行数据(python读取txt文件并取其某一列数据的示例)
- pythonlambda是什么函数(Python之lambda匿名函数及map和filter的用法)
- python中列表操作五种常用方法(Python使用paramiko操作linux的方法讲解)
- python指定参数教程(详解Python传入参数的几种方法)
- ocr公式识别python(初探利用Python进行图文识别OCR)
- python mongodb 基本操作(Python使用pymongo库操作MongoDB数据库的方法实例)
- python远程下发shell指令(Python实现堡垒机模式下远程命令执行操作示例)
- python怎么实现链表(Python实现数据结构线性链表单链表算法示例)
- python外部如何调嵌套函数(python中嵌套函数的实操步骤)
- python3.7手册中文版(Python3.4解释器用法简单示例)
- python创建字典的代码(Python创建字典的八种方式)
- python函数使用方法高级用法(Python函数的参数常见分类与用法实例详解)
- 营养餐是什么(学校营养餐是什么)
- 谁说女子不如男 范冰冰演的武则天只是其一,另外两位你认识吗(谁说女子不如男)
- 杯酒人生---瓦伦丁酒杯和奥丁格啤酒(杯酒人生---瓦伦丁酒杯和奥丁格啤酒)
- 中秋节买啤酒,预算超过7元试试这8种啤酒,麦香浓郁都是真啤酒(预算超过7元试试这8种啤酒)
- CellPress旗下的6 期刊,国人友刊来了解一下吧(CellPress旗下的6期刊国人友刊来了解一下吧)
- ()
热门推荐
- react的基本知识(React中refs的一些常见用法汇总)
- 宝塔面板防火墙是自动开的吗(宝塔面板开启隐藏的 waf 防火墙的方法)
- webview获取html(webView加载html图片遇到的问题解决)
- css圆角阴影代码(CSS实现曲面阴影效果的简单实例推荐)
- mysql服务器端安装步骤(windows下jsp+mysql网站环境配置方法)
- mysql8.0.25安装教程(Mysql8.0.17安装教程推荐)
- dedecms频道封面不能修改内容(dedecms按栏目名首字母/数字排序输出的实现方法)
- python程序开发过程(python调用外部程序的实操步骤)
- laravel 模块目录(Laravel框架文件上传功能实现方法示例)
- python爬虫并保存excel实例(Python实现爬取亚马逊数据并打印出Excel文件操作示例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9