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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/291459.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

全球增长最快域名解析商Top10:中国占据四席

IDC评述网(idcps.com)04月29日报道:根据国外域名统计机构DailyChanges最新实时数据显示,4月27日,在全球增长最快的十家域名解析服务商榜单中,中国占据四个席位。上榜的中国域名解析商分别是:51D…

webpake-node-sass 报错

问题描述: npm run dev 就报错,在安装node-sass错误 解决方法 : 找到node_modules下的node-sass文件,进入,如果没有vendor文件夹,就创建一个空文件夹,命名为vendor。 1:下载 对于版本的 binding…

C++之‘nullptr’ was not declared in this scope

在vim里面写了一个简单cpp文件,为了避免野指针,需要指针初始化 char *p2 = nullptr 1、编译时报错如下 2、解决办法 编译加上 g++ -std=gnu++0x int.cpp -o int 3、C里面的null和C++里面的nullptr、NULL介绍 NULL在C++中的定义 /* Define NULL pointer value */ #ifndef …

IOS原生地图与高德地图

原生地图 1、什么是LBS LBS: 基于位置的服务 Location Based Service 实际应用:大众点评,陌陌,微信,美团等需要用到地图或定位的App 2、定位方式 1.GPS定位 2.基站定位 3.WIFI定位 3、框架 MapKit:地图框架,显示地图 …

想说爱你不容易 | 使用最小 WEB API 实现文件上传

前言在 .NET 6 之前&#xff0c;实现文件上传功能十分简单&#xff1a;[HttpPost("upload")] public async Task<IActionResult> Upload(IFormFile file) {//对file执行操作return Ok(file.FileName); }但是&#xff0c;当使用 .NET 6 的最小 WEB API 来实现相…

python商用_python实现sm2和sm4国密(国家商用密码)算法的示例

GMSSL模块介绍GmSSL是一个开源的加密包的python实现&#xff0c;支持SM2/SM3/SM4等国密(国家商用密码)算法、项目采用对商业应用友好的类BSD开源许可证&#xff0c;开源且可以用于闭源的商业应用。安装模块pip install gmsslSM2算法RSA算法的危机在于其存在亚指数算法&#xff…

Android下载文件

2019独角兽企业重金招聘Python工程师标准>>> package com.test;import java.io.File;import java.io.FileOutputStream;import java.io.InputStream;import java.net.URL;import java.net.URLConnection;import android.app.Activity;import android.content.Intent…

C++之operator关键字(重载操作符) 使用总结

operator是C++的关键字,它和运算符一起使用,表示一个运算符函数, 一、为什么使用操作符重载 简单的说我们基本数据比如int float 都可以比较大小 有>、<、=,但是对象需要比较大小怎么办,我们也可以用>、<、=,只不过我们需要一个通用的规范比较对象的属性…

#HTTP协议学习# (七)cookie

本文转自&#xff1a;http://www.cnblogs.com/TankXiao/archive/2012/12/12/2794160.html Cookie是HTTP协议中非常重要的东西&#xff0c; 之前拜读了Fish Li 写的【细说Cookie】&#xff0c; 让我学到了很多东西。Fish的这篇文章写得太经典了。 所以我这篇文章就没有太多内容了…

C#中的类型~存储~变量

欢迎您成为我的读者&#xff0c;希望这篇文章能给你一些帮助。前言今天在群里看到朋友讨论把粉丝称为读者&#xff0c;这让我内心特别激动。以前我还是比较关注自己的文章阅读量&#xff0c;有没有人转发&#xff0c;今天新增多少个关注。而现在&#xff0c;我的关注点变了&…

sql-逻辑循环while if

--计算1-100的和declare int int1;declare total int0;while(int<100)beginset totaltotalint;set intint 1;endselect total--计算1-100偶数的和declare index int;declare sum int;set index1;set sum0;while(index<100)beginif(index%20)beginset sumsumindexendset i…

mysql常用cmd指令_Mysql cmd 常用命令

连接&#xff1a;mysql -h主机地址 -u用户名 &#xff0d;p用户密码 (注:u与root可以不用加空格&#xff0c;其它也一样)断开&#xff1a;exit (回车)创建授权&#xff1a;grant select on 数据库.* to 用户名登录主机 identified by \"密码\"修改密码&#xff1a;my…

C++之typename

1、typename和class 在模板前,typename和class没有区别 template<typename T> class A; template<class T> class A;typename和class对编译器而言却是不同的东西 2、声明一个类型 看下面的代码 我们编译下结果如下 编译器不知道T::const_iterator是个类型。如果…

ubuntu 的QT4的qmake失败的处理方法

安装qt4以后使用命令行编译时出现一下错误&#xff1a;administratorubuntu:~/qt/qt-book/chap01/hello$ qmake hello.pro程序 qmake 已包含在以下软件包中&#xff1a;* qt3-dev-tools* qt4-qmake试试&#xff1a;sudo apt-get install <选定的软件包>bash: qmake&#…

gulp与webpack的区别

常有人拿gulp与webpack来比较&#xff0c;知道这两个构建工具功能上有重叠的地方&#xff0c;可单用&#xff0c;也可一起用&#xff0c;但本质的区别就没有那么清晰。 gulp gulp强调的是前端开发的工作流程&#xff0c;我们可以通过配置一系列的task&#xff0c;定义task处理的…

mooc数据结构与算法python版期末考试_数据结构与算法Python版-中国大学mooc-试题题目及答案...

数据结构与算法Python版-中国大学mooc-试题题目及答案更多相关问题婴儿出生一两天后就有笑的反应&#xff0c;这种笑的反应属于()。【判断题】填制原始凭证&#xff0c;汉字大写金额数字一律用正楷或草书书写&#xff0c;汉字大写金额数字到元位或角位为止的&#xff0c;后面必…

使用 NetCoreBeauty 优化 .NET CORE 独立部署目录结构

在将一个 .NET CORE \ .NET 5.0 \ .NET 6.0 程序进行独立部署发布时&#xff0c;会在发布目录产生很多系统类库&#xff0c;导致目录非常不简洁。这给寻找入口程序造成了困难&#xff0c;特别是路遥工具箱这种绿色软件&#xff0c;不会在开始菜单、系统桌面创建快捷方式&#x…

关于注释

在编写程序时&#xff0c;应当给程序添加一些注释&#xff0c;用于说明某段代码的作用&#xff0c;或者说明某个类的用途&#xff0c;某个方法的功能&#xff0c;以及该方法的参数和返回值类型和意义等。 很多初学者开始学习编程语言时&#xff0c;会很努力写程序&#xff0c;但…

从此不再惧怕URI编码:JavaScript及C# URI编码详解

混乱的URI编码 JavaScript中编码有三种方法:escape、encodeURI、encodeURIComponent C#中编码主要方法&#xff1a;HttpUtility.UrlEncode、Server.UrlEncode、Uri.EscapeUriString、Uri.EscapeDataString JavaScript中的还好&#xff0c;只提供了三个&#xff0c;C#中主要用的…

ios之最简单的程序

1、构建学生对象并且打印相关信息 代码&#xff1a;#import <UIKit/UIKit.h> #import "AppDelegate.h"interface Student : NSObject //变量 property NSString *name; property int age; property float score;//method -(void)show;endimplementation Studen…