进程Process是对各种资源管理的集合,包含对各种资源的调用、内存的管理、网络接口的调用;一个进程Process可以包含多个子进程,启动一个进程的时候会自动创建一个线程,进程里的第一个线程就是主线程(即python __name__ == ‘__main__');
进程Process模块
对于线程操作可以用threading模块,那么对于进程的创建python同样也提供了Process模块,创建进程时需要导入该模块,语法如下:
# 导入进程模块 from multiprocessing import Process # 创建进程 p = Process(group=None, target=None, name=None, args=(), kwargs={})
参数介绍:
group — 参数未使用,默认值为None;
target — 表示调用对象,即子进程要执行的任务(函数名字);
args — 子进程对应函数的参数,并且类型是元组tuple;
kwargs — 子进程对应函数的参数,并且类型是字典dict,如kwargs = {‘name':Jack, ‘age':18};
name — 子进程名称;
返回值:返回进程实例对象;
三.进程Process函数介绍
其实进程Process的函数和线程threading类似,具体如下:
1.start() — 启动进程;
2.terminate() — 强制终止进程,不会进行任何清理操作。如果该进程终止前,创建了子进程,那么该子进程在其强制结束后变为僵尸进程;如果该进程还保存了一个锁那么也将不会被释放,进而导致死锁,使用时,要注意;
3.is_alive() — 判断某进程是否存活,存活返回True,否则False;
4.join([timeout]) — 主线程等待子线程终止。timeout为可选择超时时间;需要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程 ;
5.daemon — 默认值为False,如果设置为True,代表该进程为后台守护进程;当该进程的父进程终止时,该进程也随之终止;并且设置为True后,该进程不能创建子进程,设置该属性必须在start()之前;
6.name — 进程名称;
7.pid— 进程ID标识,pid,值得注意的是:如果在start函数之前获取pid默认为None,因为进程还未创建,获取不到pid;
8.exitcode — 进程运行时为None,如果为-N,表示被信号N结束了;
9.authkey — 进程身份验证,默认是由os.urandom()随机生成32字符的字符串。这个键的用途是设计涉及网络连接的底层进程间的通信提供安全性,这类连接只有在具有相同身份验证才能成功;
进程Process使用
# !usr/bin/env python # -*- coding:utf-8 _*- """ @Author:何以解忧 @Blog(个人博客地址): shuopython.com @WeChat Official Account(微信公众号):猿说python @Github:www.github.com @File:python_process.py @Time:2019/12/21 21:25 @Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累! """ from multiprocessing import Process def people_info(*args,**kwargs): print(args,kwargs) def main(): # 信息列表 list_info = [{"name":"zhangsan","height":"175cm"}, {"name": "lisi", "height": "155cm"}, {"name": "wangwu", "height": "195cm"}, {"name": "liqi", "height": "166cm"}, {"name": "wangba", "height": "125cm"},] # 创建进程 for i in range(5): p = Process(target=people_info,args=(i,),kwargs=list_info[i]) # 设置为守护进程,必须设置在start函数之前,否则会产生异常 # 默认为False,即主进程会等待子进程结束之后才结束, # 如果设置为True,主进程结束之后所有的子进程自动结束,不管子进程是否已经执行完所有任务 # p.daemon = True # 启动进程 p.start() # 获取进程pid,如果在start函数之前获取pid,默认为None,因为进程还没启动 print("进程process pid = ",p.pid) # 获取进程名字 print("进程process name = ",p.name) # 获取进程pid print("进程process exitcode = ",p.exitcode) if __name__ == "__main__": main()
输出结果:
进程process pid = 2600 进程process name = Process-1 进程process exitcode = None 进程process pid = 4372 进程process name = Process-2 进程process exitcode = None 进程process pid = 14124 进程process name = Process-3 进程process exitcode = None 进程process pid = 10920 进程process name = Process-4 进程process exitcode = None 进程process pid = 4892 进程process name = Process-5 进程process exitcode = None (0,) {'name': 'zhangsan', 'height': '175cm'} (1,) {'name': 'lisi', 'height': '155cm'} (2,) {'name': 'wangwu', 'height': '195cm'} (3,) {'name': 'liqi', 'height': '166cm'} (4,) {'name': 'wangba', 'height': '125cm'}
小窍门:
Python 的 os 模块封装了常见的系统调用,其中就包括:
os.fork() 创建子进程
os.getpid() 获取自身 ID
os.getppid() 获取父进程 ID
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
您可以通过各种方式使用Perl来根据您的要求创建新流程。 本教程将列出几个重要且最常用的创建和管理Perl进程的方法。 您可以使用特殊变量$$或$PROCESS_ID来获取当前进程ID。 使用任何上述方法创建的每个进程都使用%ENV变量维护自己的虚拟环境。 exit()函数总是只退出执行此函数的子进程,并且除非所有正在运行的子进程都已退出,否则整个主进程不会退出。 所有打开的句柄都是子进程中的du
本文向大家介绍Nodejs进程管理模块forever详解,包括了Nodejs进程管理模块forever详解的使用技巧和注意事项,需要的朋友参考一下 接下来,就让我们看看forever能不能实现目标。 一、forever介绍 forever是一个简单的命令式nodejs的守护进程,能够启动,停止,重启App应用。forever完全基于命令行操作,在forever进程之下,创建node的子进程,通过m
一、简介 V9系统可以自定义开发模块(详情请参考V9二次开发指南)。可对模块的安装,卸载等管理。 二、功能演示 1.安装 将已经创建好的模块放在指定位置,运行后台后,在“模块管理”处会找到你创建的模块。如下图: 如模块配置和代码无问题,系统将提示安装成功,否则提示错误。安装成功后你就可以使用该模块了(详情请参考V9二次开发指南)。 2.卸载 安装后的模块如果你不需要,可进行卸载。如下图:
一、简介 “模块管理"用于用户管理系统自带或者用户自定义开发模块的设置以及配置的等。这里且说系统自带。 二、功能演示 表单向导 广告 新闻心情 短消息 投票 友情链接 评论 公告 模块管理 全站搜素 数据源 点评模块 物流模块 在线充值 短信平台 外部数据导入 手机门户
process 对象是一个 global (全局变量),提供有关信息,控制当前 Node.js 进程。作为一个对象,它对于 Node.js 应用程序始终是可用的,故无需使用 require()。 Process Events process 对象是EventEmitter的实例. Event: 'beforeExit' 新增于: v0.11.12 当Node.js的事件循环数组已经为空,并且没有额
本文向大家介绍Python Process多进程实现过程,包括了Python Process多进程实现过程的使用技巧和注意事项,需要的朋友参考一下 进程的概念 程序是没有运行的代码,静态的; 进程是运行起来的程序,进程是一个程序运行起来之后和资源的总称; 程序只有一个,但同一份程序可以有多个进程;例如,电脑上多开QQ; 程序和进程的区别在于有没有资源,进程有资源而程序没有资源,进程是一个资源分配的