系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 脚本中心 > python > 详细页面

Python使用进程Process模块管理资源

时间:2020-03-05来源:电脑系统城作者:电脑系统城

进程Process是对各种资源管理的集合,包含对各种资源的调用、内存的管理、网络接口的调用;一个进程Process可以包含多个子进程,启动一个进程的时候会自动创建一个线程,进程里的第一个线程就是主线程(即python __name__ == ‘__main__');

进程Process模块

对于线程操作可以用threading模块,那么对于进程的创建python同样也提供了Process模块,创建进程时需要导入该模块,语法如下:


 
  1. # 导入进程模块
  2. from multiprocessing import Process
  3. # 创建进程
  4. 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使用


 
  1. # !usr/bin/env python
  2. # -*- coding:utf-8 _*-
  3. """
  4. @Author:何以解忧
  5. @Blog(个人博客地址): shuopython.com
  6. @WeChat Official Account(微信公众号):猿说python
  7. @Github:www.github.com
  8.  
  9. @File:python_process.py
  10. @Time:2019/12/21 21:25
  11.  
  12. @Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累!
  13. """
  14.  
  15. from multiprocessing import Process
  16.  
  17.  
  18. def people_info(*args,**kwargs):
  19. print(args,kwargs)
  20.  
  21.  
  22.  
  23. def main():
  24.  
  25. # 信息列表
  26. list_info = [{"name":"zhangsan","height":"175cm"},
  27. {"name": "lisi", "height": "155cm"},
  28. {"name": "wangwu", "height": "195cm"},
  29. {"name": "liqi", "height": "166cm"},
  30. {"name": "wangba", "height": "125cm"},]
  31.  
  32. # 创建进程
  33. for i in range(5):
  34. p = Process(target=people_info,args=(i,),kwargs=list_info[i])
  35. # 设置为守护进程,必须设置在start函数之前,否则会产生异常
  36. # 默认为False,即主进程会等待子进程结束之后才结束,
  37. # 如果设置为True,主进程结束之后所有的子进程自动结束,不管子进程是否已经执行完所有任务
  38. # p.daemon = True
  39.  
  40. # 启动进程
  41. p.start()
  42.  
  43. # 获取进程pid,如果在start函数之前获取pid,默认为None,因为进程还没启动
  44. print("进程process pid = ",p.pid)
  45. # 获取进程名字
  46. print("进程process name = ",p.name)
  47. # 获取进程pid
  48. print("进程process exitcode = ",p.exitcode)
  49. if __name__ == "__main__":
  50. main()

输出结果:


 
  1. 进程process pid = 2600
  2. 进程process name = Process-1
  3. 进程process exitcode = None
  4. 进程process pid = 4372
  5. 进程process name = Process-2
  6. 进程process exitcode = None
  7. 进程process pid = 14124
  8. 进程process name = Process-3
  9. 进程process exitcode = None
  10. 进程process pid = 10920
  11. 进程process name = Process-4
  12. 进程process exitcode = None
  13. 进程process pid = 4892
  14. 进程process name = Process-5
  15. 进程process exitcode = None
  16. (0,) {'name': 'zhangsan', 'height': '175cm'}
  17. (1,) {'name': 'lisi', 'height': '155cm'}
  18. (2,) {'name': 'wangwu', 'height': '195cm'}
  19. (3,) {'name': 'liqi', 'height': '166cm'}
  20. (4,) {'name': 'wangba', 'height': '125cm'}

小窍门:

Python 的 os 模块封装了常见的系统调用,其中就包括:

os.fork() 创建子进程
os.getpid() 获取自身 ID
os.getppid() 获取父进程 ID

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

分享到:

相关信息

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载