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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。