时间:2021-05-22
前面介绍了使用 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 种方法做详细的讲解。
和使用 thread 类创建子线程的方式非常类似,使用 Process 类创建实例化对象,其本质是调用该类的构造方法创建新进程。Process 类的构造方法格式如下:
其中,各个参数的含义为:
下面程序演示了如何用 Process 类创建新进程。
程序执行结果为:
当前进程ID: 12980
主进程
http://jb51.net/python/ --当前进程12980
http://jb51.net/shell/ --当前进程12980
http://jb51.net/java/ --当前进程12980
当前进程ID: 12860
my_process进程
http://jb51.net/python/ --当前进程12860
http://jb51.net/shell/ --当前进程12860
http://jb51.net/java/ --当前进程12860
需要说明的是,通过 multiprocessing.Process 来创建并启动进程时,程序必须先判断 if __name__=='__main__':,否则运行该程序会引发异常。
此程序中有 2 个进程,分别为主进程和我们创建的新进程,主进程会执行整个程序,而子进程不会执行 if __name__ == '__main__' 中包含的程序,而是先执行此判断语句之外的所有可执行程序,然后再执行我们分配让它的任务(也就是通过 target 参数指定的函数)。
和使用 thread 子类创建线程的方式类似,除了直接使用 Process 类创建进程,还可以通过创建 Process 的子类来创建进程。
需要注意的是,在创建 Process 的子类时,需在子类内容重写 run() 方法。实际上,该方法所起到的作用,就如同第一种创建方式中 target 参数执行的函数。
另外,通过 Process 子类创建进程,和使用 Process 类一样,先创建该类的实例对象,然后调用 start() 方法启动该进程。下面程序演示如何通过 Process 子类创建一个进程。
程序执行结果为:
当前进程ID: 22240
主进程
http://jb51.net/python/ --当前进程22240
http://jb51.net/shell/ --当前进程22240
http://jb51.net/java/ --当前进程22240
当前进程ID: 18848
my_process进程
http://jb51.net/python/ --当前进程18848
http://jb51.net/shell/ --当前进程18848
http://jb51.net/java/ --当前进程18848
显然,该程序的运行结果与上一个程序的运行结果大致相同,它们只是创建进程的方式略有不同而已。
推荐读者使用第一种方式来创建进程,因为这种方式不仅编程简单,而且进程直接包装 target 函数,具有更清晰的逻辑结构。
到此这篇关于Python Process创建进程的2种方法详解的文章就介绍到这了,更多相关Python Process创建进程内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Android上杀掉进程的方式有两种,分别是System.exit(0)和Process.killProcess(Process.myPid()),这两种方法比
本文实例讲述了python开启多个子进程并行运行的方法。分享给大家供大家参考。具体如下:这个python代码创建了多个process子进程,创建完成后先star
python自定义异常实例详解本文通过两种方法对Python自定义异常进行讲解,第一种:创建一个新的exception类来拥有自己的异常,第二种:raise唯一
Chrome支持Process-per-site-instance、Process-per-site、Process-per-tab三种多进程策略和Single
Process类的作用是对系统进程进行管理,我们使用Process类中的一些方法结合Winform开发个简单的进程管理器:在使用Process类的时候,先导入命