Python使用进程Process模块管理资源
进程Process是对各种资源管理的集合,包含对各种资源的调用、内存的管理、网络接口的调用;一个进程Process可以包含多个子进程,启动一个进程的时候会自动创建一个线程,进程里的第一个线程就是主线程(即python__name__==‘__main__');
进程Process模块
对于线程操作可以用threading模块,那么对于进程的创建python同样也提供了Process模块,创建进程时需要导入该模块,语法如下:
#导入进程模块
frommultiprocessingimportProcess
#创建进程
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/envpython
#-*-coding:utf-8_*-
"""
@Author:何以解忧
@Blog(个人博客地址):shuopython.com
@WeChatOfficialAccount(微信公众号):猿说python
@Github:www.github.com
@File:python_process.py
@Time:2019/12/2121:25
@Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累!
"""
frommultiprocessingimportProcess
defpeople_info(*args,**kwargs):
print(args,kwargs)
defmain():
#信息列表
list_info=[{"name":"zhangsan","height":"175cm"},
{"name":"lisi","height":"155cm"},
{"name":"wangwu","height":"195cm"},
{"name":"liqi","height":"166cm"},
{"name":"wangba","height":"125cm"},]
#创建进程
foriinrange(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("进程processpid=",p.pid)
#获取进程名字
print("进程processname=",p.name)
#获取进程pid
print("进程processexitcode=",p.exitcode)
if__name__=="__main__":
main()
输出结果:
进程processpid=2600
进程processname=Process-1
进程processexitcode=None
进程processpid=4372
进程processname=Process-2
进程processexitcode=None
进程processpid=14124
进程processname=Process-3
进程processexitcode=None
进程processpid=10920
进程processname=Process-4
进程processexitcode=None
进程processpid=4892
进程processname=Process-5
进程processexitcode=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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。