前面介绍了使用 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://jb51.net/python/",\

"http://jb51.net/shell/",\

"http://jb51.net/java/")

#创建子进程,执行 action() 函数

my_process = Process(target = action, args = ("my_process进程",*my_tuple))

#启动子进程

my_process.start()

#主进程执行该函数

action("主进程",*my_tuple)

程序执行结果为:

当前进程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 参数指定的函数)。

通过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://jb51.net/python/",\

"http://jb51.net/shell/",\

"http://jb51.net/java/")

my_process = My_Process("my_process进程",*my_tuple)

#启动子进程

my_process.start()

#主进程执行该函数

action("主进程",*my_tuple)

程序执行结果为:

当前进程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创建进程内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

python process 函数_Python Process创建进程的2种方法详解相关推荐

  1. python怎么截取字符串函数_Python截取字符串(字符串切片)方法详解

    字符串本质上就是由多个字符组成的,因此程序允许通过索引来操作字符,比如获取指定索引处的字符,获取指定字符在字符串中的位置等. Python字符串直接在方括号([])中使用索引即可获取对应的字符,字符串 ...

  2. python视觉识别字_Python怎么识别文字?正确 的方法详解

    爬虫--文字识别 机器视觉 从Google的无人驾驶汽车到可以识别假钞的自动售卖机,机器视觉一直都是一个应用广泛且具有深远的影响和雄伟的愿景的领域. 这里我们将重点介绍机器视觉的一个分支:文字识别.介 ...

  3. python tcp服务器_python实现TCP服务器端与客户端的方法详解

    本文实例讲述了python实现TCP服务器端与客户端的方法.分享给大家供大家参考.具体如下: TCP服务器程序(tsTserv.py): from socket import * from time ...

  4. python复制列表元素_Python学习教程:Python列表赋值,复制,深拷贝及5种浅拷贝详解...

    Python学习教程:Python列表赋值,复制,深拷贝及5种浅拷贝详解 概述 在列表复制这个问题,看似简单的复制却有着许多的学问,尤其是对新手来说,理所当然的事情却并不如意,比如列表的赋值.复制.浅 ...

  5. python输入字符串并反序result_python字符串反转的四种方法详解

    python字符串反转的四种方法详解 这篇文章主要介绍了python字符串反转的四种详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.用red ...

  6. 站长在线Python精讲:在Python中格式化字符串的两种方法详解

    欢迎你来到站长在线的站长学堂学习Python知识,本文学习的是<在Python中格式化字符串的两种方法详解>.本知识点主要内容有:使用%操作符格式化字符串和使用format()方法格式化字 ...

  7. python 命令-python解析命令行参数的三种方法详解

    这篇文章主要介绍了python解析命令行参数的三种方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 python解析命令行参数主要有三种方法: ...

  8. python截图黑屏_对Python获取屏幕截图的4种方法详解

    Python获取电脑截图有多种方式,具体如下: PIL中的ImageGrab模块 windows API PyQt pyautogui PIL中的ImageGrab模块 import time imp ...

  9. python接收邮件内容启动程序_Python实现发送与接收邮件的方法详解

    本文实例讲述了Python实现发送与接收邮件的方法.分享给大家供大家参考,具体如下: 一.发送邮件 这里实现给网易邮箱发送邮件功能: import smtplib import tkinter cla ...

最新文章

  1. JAVA用最简单的方法来构建一个高可用的服务端,提升系统可用性
  2. 更换pip安装源头成阿里云或清华的
  3. 计算机网络技术实训应用层,计算机网络技术
  4. emacs 新手笔记(四) —— 使用 dired 完成一些简单的文件和目录操作
  5. spring编程式事务控制
  6. wordcloud用来制作中文词云
  7. node --- [node接口阅读]cluster的使用
  8. “视网膜”重装来袭 AI技术为视频业务场景赋能
  9. 【scrapy】学习Scrapy入门
  10. 基于JAVA+SpringMVC+Mybatis+MYSQL的在线作业管理系统
  11. Intel 的 micro-architecture 发展历程
  12. CTF—古典密码(凯撒密码、维吉尼亚密码、培根密码等)
  13. Python/下载数据
  14. 小白调用soso街景API
  15. 模型保存文件.npy
  16. 洛谷 P1653 猴子 解题报告
  17. 批处理Bat教程-第七章:常用实例 下
  18. python实验楼工资计算器_挑战:完善工资计算器
  19. 404 网站服务器错误怎么解决,网站404错误页面是什么意思,它有什么用?
  20. A-Priori算法及其优化(FP树)

热门文章

  1. C#知多少 | 每个版本都更新了什么?
  2. 我们真的需要JWT吗?
  3. Gartner:6个容器和Kubernetes策略的最佳实用技巧
  4. .Net Core3.1下使用Swagger搭建web api项目
  5. Visual Studio Online 的 FAQ:iPad 支持、自托管环境、Azure 账号等
  6. .NET Core 3.0之深入源码理解Host(二)
  7. 项目实战中如何使用抽象类和接口
  8. .NetCore 2.1以后的HttpClient最佳实践
  9. [Abp vNext 源码分析] - 4. 工作单元
  10. 使用 WeihanLi.Npoi 操作 CSV