Python Process创建进程的2种方法详解


Posted in Python onJanuary 25, 2021

前面介绍了使用 os.fork() 函数实现多进程编程,该方法最明显的缺陷就是不适用于 Windows 系统。本节将介绍一种支持 Python 在 Windows 平台上创建新进程的方法。

Python multiprocessing 模块提供了 Process 类,该类可用来在 Windows 平台上创建新进程。和使用 Thread 类创建多线程方法类似,使用 Process 类创建多进程也有以下 2 种方式:

直接创建 Process 类的实例对象,由此就可以创建一个新的进程;

通过继承 Process 类的子类,创建实例对象,也可以创建新的进程。注意,继承 Process 类的子类需重写父类的 run() 方法。

不仅如此,Process 类中也提供了一些常用的属性和方法,如表 1 所示。

属性名或方法名 功能
run() 第 2 种创建进程的方式需要用到,继承类中需要对方法进行重写,该方法中包含的是新进程要执行的代码。
start() 和启动子线程一样,新创建的进程也需要手动启动,该方法的功能就是启动新创建的线程。
join([timeout]) 和 thread 类 join() 方法的用法类似,其功能是在多进程执行过程,其他进程必须等到调用 join() 方法的进程执行完毕(或者执行规定的 timeout 时间)后,才能继续执行;
is_alive() 判断当前进程是否还活着。
terminate() 中断该进程。
name属性 可以为该进程重命名,也可以获得该进程的名称。
daemon 和守护线程类似,通过设置该属性为 True,可将新建进程设置为“守护进程”。
pid 返回进程的 ID 号。大多数操作系统都会为每个进程配备唯一的 ID 号。

表 1 Python Process类常用属性和方法

接下来将一一对创建进程的 2 种方法做详细的讲解。

通过Process类创建进程

和使用 thread 类创建子线程的方式非常类似,使用 Process 类创建实例化对象,其本质是调用该类的构造方法创建新进程。Process 类的构造方法格式如下:

def __init__(self,group=None,target=None,name=None,args=(),kwargs={})

其中,各个参数的含义为:

  • group:该参数未进行实现,不需要传参;
  • target:为新建进程指定执行任务,也就是指定一个函数;
  • name:为新建进程设置名称;
  • args:为 target 参数指定的参数传递非关键字参数;
  • kwargs:为 target 参数指定的参数传递关键字参数。

下面程序演示了如何用 Process 类创建新进程。

from multiprocessing import Process
import os
print("当前进程ID:",os.getpid())
# 定义一个函数,准备作为新进程的 target 参数
def action(name,*add):
 print(name)
 for arc in add:
  print("%s --当前进程%d" % (arc,os.getpid()))
if __name__=='__main__':
 #定义为进程方法传入的参数
 my_tuple = ("http://3water.com/python/",\
    "http://3water.com/shell/",\
    "http://3water.com/java/")
 #创建子进程,执行 action() 函数
 my_process = Process(target = action, args = ("my_process进程",*my_tuple))
 #启动子进程
 my_process.start()
 #主进程执行该函数
 action("主进程",*my_tuple)

程序执行结果为:
当前进程ID: 12980
主进程
http://3water.com/python/ --当前进程12980
http://3water.com/shell/ --当前进程12980
http://3water.com/java/ --当前进程12980
当前进程ID: 12860
my_process进程
http://3water.com/python/ --当前进程12860
http://3water.com/shell/ --当前进程12860
http://3water.com/java/ --当前进程12860

需要说明的是,通过 multiprocessing.Process 来创建并启动进程时,程序必须先判断 if __name__=='__main__':,否则运行该程序会引发异常。

此程序中有 2 个进程,分别为主进程和我们创建的新进程,主进程会执行整个程序,而子进程不会执行 if __name__ == '__main__' 中包含的程序,而是先执行此判断语句之外的所有可执行程序,然后再执行我们分配让它的任务(也就是通过 target 参数指定的函数)。

通过Process继承类创建进程

和使用 thread 子类创建线程的方式类似,除了直接使用 Process 类创建进程,还可以通过创建 Process 的子类来创建进程。

需要注意的是,在创建 Process 的子类时,需在子类内容重写 run() 方法。实际上,该方法所起到的作用,就如同第一种创建方式中 target 参数执行的函数。

另外,通过 Process 子类创建进程,和使用 Process 类一样,先创建该类的实例对象,然后调用 start() 方法启动该进程。下面程序演示如何通过 Process 子类创建一个进程。

from multiprocessing import Process
import os
print("当前进程ID:",os.getpid())
# 定义一个函数,供主进程调用
def action(name,*add):
 print(name)
 for arc in add:
  print("%s --当前进程%d" % (arc,os.getpid()))
#自定义一个进程类
class My_Process(Process):
 def __init__(self,name,*add):
  super().__init__()
  self.name = name
  self.add = add
 def run(self):
  print(self.name)
  for arc in self.add:
   print("%s --当前进程%d" % (arc,os.getpid()))
if __name__=='__main__':
 #定义为进程方法传入的参数
 my_tuple = ("http://3water.com/python/",\
    "http://3water.com/shell/",\
    "http://3water.com/java/")
 my_process = My_Process("my_process进程",*my_tuple)
 #启动子进程
 my_process.start()
 #主进程执行该函数
 action("主进程",*my_tuple)

程序执行结果为:
当前进程ID: 22240
主进程
http://3water.com/python/ --当前进程22240
http://3water.com/shell/ --当前进程22240
http://3water.com/java/ --当前进程22240
当前进程ID: 18848
my_process进程
http://3water.com/python/ --当前进程18848
http://3water.com/shell/ --当前进程18848
http://3water.com/java/ --当前进程18848

显然,该程序的运行结果与上一个程序的运行结果大致相同,它们只是创建进程的方式略有不同而已。
推荐读者使用第一种方式来创建进程,因为这种方式不仅编程简单,而且进程直接包装 target 函数,具有更清晰的逻辑结构。

到此这篇关于Python Process创建进程的2种方法详解的文章就介绍到这了,更多相关Python Process创建进程内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python使用BeautifulSoup分页网页中超链接的方法
Apr 04 Python
编写Python的web框架中的Model的教程
Apr 29 Python
python统计文本文件内单词数量的方法
May 30 Python
python实现多线程的两种方式
May 22 Python
对pandas进行数据预处理的实例讲解
Apr 20 Python
python用户评论标签匹配的解决方法
May 31 Python
pycharm在调试python时执行其他语句的方法
Nov 29 Python
Python selenium根据class定位页面元素的方法
Feb 26 Python
解决Django中修改js css文件但浏览器无法及时与之改变的问题
Aug 31 Python
python 经典数字滤波实例
Dec 16 Python
解决pycharm中导入自己写的.py函数出错问题
Feb 12 Python
python GUI库图形界面开发之PyQt5中QMainWindow, QWidget以及QDialog的区别和选择
Feb 26 Python
使用python对excel表格处理的一些小功能
Jan 25 #Python
全网最详细的PyCharm+Anaconda的安装过程图解
Jan 25 #Python
python 数据类型强制转换的总结
Jan 25 #Python
如何用Python徒手写线性回归
Jan 25 #Python
Python try except finally资源回收的实现
Jan 25 #Python
Python中lru_cache的使用和实现详解
Jan 25 #Python
详解Python之Scrapy爬虫教程NBA球员数据存放到Mysql数据库
Jan 24 #Python
You might like
火影忍者:这才是千手柱间和扉间的真正死因,角都就比较搞笑了!
2020/03/10 日漫
分享PHP源码批量抓取远程网页图片并保存到本地的实现方法
2015/12/01 PHP
laravel5实现微信第三方登录功能
2018/12/06 PHP
Laravel timestamps 设置为unix时间戳的方法
2019/10/11 PHP
javascript 24小时弹出一次的代码(利用cookies)
2009/09/03 Javascript
JavaScript实现多个重叠层点击切换效果的方法
2015/04/24 Javascript
jquery动感漂浮导航菜单代码分享
2020/04/15 Javascript
Bootstrap布局之栅格系统详解
2016/06/13 Javascript
JS实现的跨浏览器解析XML文件实例
2016/06/21 Javascript
移动端日期插件Mobiscroll.js使用详解
2016/12/19 Javascript
Avalonjs 实现简单购物车功能(实例代码)
2017/02/07 Javascript
详解基于vue-cli优化的webpack配置
2017/11/06 Javascript
VueJs使用Amaze ui调整列表和内容页面
2017/11/30 Javascript
详解微信小程序与内嵌网页交互实现支付功能
2018/10/22 Javascript
JS实现checkbox互斥(单选)功能示例
2019/05/04 Javascript
通过seajs实现JavaScript的模块开发及按模块加载
2019/06/06 Javascript
JS原型和原型链原理与用法实例详解
2020/02/05 Javascript
[05:46]DOTA2英雄梦之声_第18期_陈
2014/06/20 DOTA
[33:15]2018DOTA2亚洲邀请赛3月30日 小组赛B组 VP VS Mineski
2018/03/31 DOTA
idea创建springMVC框架和配置小文件的教程图解
2018/09/18 Python
Python OpenCV读取png图像转成jpg图像存储的方法
2018/10/28 Python
Python多进程方式抓取基金网站内容的方法分析
2019/06/03 Python
Python3中的最大整数和最大浮点数实例
2019/07/09 Python
python实现字符串完美拆分split()的方法
2019/07/16 Python
Django框架模型简单介绍与使用分析
2019/07/18 Python
在PyTorch中使用标签平滑正则化的问题
2020/04/03 Python
python主要用于哪些方向
2020/07/05 Python
python基于win32api实现键盘输入
2020/12/09 Python
PyCharm 解决找不到新打开项目的窗口问题
2021/01/15 Python
CSS3 中filter(滤镜)属性使用详解
2020/04/07 HTML / CSS
千元咖啡店的创业计划书范文
2013/12/29 职场文书
上课睡觉检讨书
2014/01/28 职场文书
会计岗位职责模板
2014/03/12 职场文书
态度决定一切演讲稿
2014/05/20 职场文书
车间主任岗位职责范本
2015/04/08 职场文书
三十年同学聚会感言
2015/07/30 职场文书