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


Posted in Python onMarch 05, 2020

进程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

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

Python 相关文章推荐
python中lambda函数 list comprehension 和 zip函数使用指南
Sep 28 Python
windows10系统中安装python3.x+scrapy教程
Nov 08 Python
Python爬虫包 BeautifulSoup  递归抓取实例详解
Jan 28 Python
Python的mysql数据库的更新如何实现
Jul 31 Python
分分钟入门python语言
Mar 20 Python
python pands实现execl转csv 并修改csv指定列的方法
Dec 12 Python
详解用python写网络爬虫-爬取新浪微博评论
May 10 Python
python读取与处理netcdf数据方式
Feb 14 Python
Python3 pickle对象串行化代码实例解析
Mar 23 Python
浅谈JupyterNotebook导出pdf解决中文的问题
Apr 22 Python
python破解同事的压缩包密码
Oct 14 Python
pytest实现多进程与多线程运行超好用的插件
Jul 15 Python
Python json模块与jsonpath模块区别详解
Mar 05 #Python
Python如何用filter函数筛选数据
Mar 05 #Python
Python API len函数操作过程解析
Mar 05 #Python
Python通过Tesseract库实现文字识别
Mar 05 #Python
Python爬虫实现模拟点击动态页面
Mar 05 #Python
python实现图片横向和纵向拼接
Mar 05 #Python
基于Python生成个性二维码过程详解
Mar 05 #Python
You might like
PHP中使用Imagick读取pdf并生成png缩略图实例
2015/01/21 PHP
PHP扩展程序实现守护进程
2015/04/16 PHP
/etc/php-fpm.d/www.conf 配置注意事项
2017/02/04 PHP
MacOS下PHP7.1升级到PHP7.4.15的方法
2021/02/22 PHP
jquery怎样实现ajax联动框(二)
2013/03/08 Javascript
nodejs 整合kindEditor实现图片上传
2015/02/03 NodeJs
jQuery制作效果超棒的手风琴折叠菜单
2015/04/03 Javascript
浅谈Javascript中substr和substring的区别
2015/09/30 Javascript
jQuery实现的网页左侧在线客服效果代码
2015/10/23 Javascript
JS实现动态添加DOM节点和事件的方法示例
2017/04/28 Javascript
react native带索引的城市列表组件的实例代码
2017/08/08 Javascript
移动设备手势事件库Touch.js使用详解
2017/08/18 Javascript
webpack vue 项目打包生成的文件,资源文件报404问题的修复方法(总结篇)
2018/01/09 Javascript
除Console.log()外更多的Javascript调试命令
2018/01/24 Javascript
深入Vue-Router路由嵌套理解
2018/08/13 Javascript
解决vue axios的封装 请求状态的错误提示问题
2018/09/25 Javascript
JavaScript 复制对象与Object.assign方法无法实现深复制
2018/11/02 Javascript
django简单的前后端分离的数据传输实例 axios
2020/05/18 Javascript
微信小程序整个页面的自动适应布局的实现
2020/07/12 Javascript
Python获取apk文件URL地址实例
2013/11/01 Python
python应用程序在windows下不出现cmd窗口的办法
2014/05/29 Python
极简的Python入门指引
2015/04/01 Python
pycharm远程调试openstack代码
2017/11/21 Python
python中sys.argv函数精简概括
2018/07/08 Python
python一行sql太长折成多行并且有多个参数的方法
2018/07/19 Python
python 阶乘累加和的实例
2019/02/01 Python
python自动化之Ansible的安装教程
2019/06/13 Python
python下PyGame的下载与安装过程及遇到问题
2019/08/04 Python
最新2019Pycharm安装教程 亲测
2020/02/28 Python
Python用户自定义异常的实现
2020/12/25 Python
韩国三大免税店之一:THE GRAND 中文免税店
2016/07/21 全球购物
斯德哥尔摩通票:Stockholm Pass
2018/01/09 全球购物
《登鹳雀楼》教学反思
2014/04/09 职场文书
出纳年终工作总结2014
2014/12/05 职场文书
2016元旦文艺汇演主持词
2015/07/06 职场文书
2016年社区服务活动总结
2016/04/06 职场文书