python进程的状态、创建及使用方法详解


Posted in Python onDecember 06, 2019

本文实例讲述了python进程的状态、创建及使用方法。分享给大家供大家参考,具体如下:

进程以及状态

1. 进程

程序:例如xxx.py这是程序,是一个静态的

进程:一个程序运行起来后,代码+用到的资源 称之为进程,它是操作系统分配资源的基本单元。

不仅可以通过线程完成多任务,进程也是可以的

2. 进程的状态

工作中,任务数往往大于cpu的核数,即一定有一些任务正在执行,而另外一些任务在等待cpu进行执行,因此导致了有了不同的状态

  • 就绪态:运行的条件都已经慢去,正在等在cpu执行
  • 执行态:cpu正在执行其功能
  • 等待态:等待某些条件满足,例如一个程序sleep了,此时就处于等待态

进程的创建-multiprocessing

multiprocessing模块就是跨平台版本的多进程模块,提供了一个Process类来代表一个进程对象,这个对象可以理解为是一个独立的进程,可以执行另外的事情

1. 2个while循环一起执行

# -*- coding:utf-8 -*-
from multiprocessing import Process
import time
def run_proc():
  """子进程要执行的代码"""
  while True:
    print("----2----")
    time.sleep(1)
if __name__=='__main__':
  p = Process(target=run_proc)
  p.start()
  while True:
    print("----1----")
    time.sleep(1)

说明

  • 创建子进程时,只需要传入一个执行函数和函数的参数,创建一个Process实例,用start()方法启动

2. 进程pid

# -*- coding:utf-8 -*-
from multiprocessing import Process
import os
import time
def run_proc():
  """子进程要执行的代码"""
  print('子进程运行中,pid=%d...' % os.getpid()) # os.getpid获取当前进程的进程号
  print('子进程将要结束...')
if __name__ == '__main__':
  print('父进程pid: %d' % os.getpid()) # os.getpid获取当前进程的进程号
  p = Process(target=run_proc)
  p.start()

3. Process语法结构如下:

Process([group [, target [, name [, args [, kwargs]]]]])

  • target:如果传递了函数的引用,可以任务这个子进程就执行这里的代码
  • args:给target指定的函数传递的参数,以元组的方式传递
  • kwargs:给target指定的函数传递命名参数
  • name:给进程设定一个名字,可以不设定
  • group:指定进程组,大多数情况下用不到

Process创建的实例对象的常用方法:

  • start():启动子进程实例(创建子进程)
  • is_alive():判断进程子进程是否还在活着
  • join([timeout]):是否等待子进程执行结束,或等待多少秒
  • terminate():不管任务是否完成,立即终止子进程

Process创建的实例对象的常用属性:

  • name:当前进程的别名,默认为Process-N,N为从1开始递增的整数
  • pid:当前进程的pid(进程号)

4. 给子进程指定的函数传递参数

# -*- coding:utf-8 -*-
from multiprocessing import Process
import os
from time import sleep
def run_proc(name, age, **kwargs):
  for i in range(10):
    print('子进程运行中,name= %s,age=%d ,pid=%d...' % (name, age, os.getpid()))
    print(kwargs)
    sleep(0.2)
if __name__=='__main__':
  p = Process(target=run_proc, args=('test',18), kwargs={"m":20})
  p.start()
  sleep(1) # 1秒中之后,立即结束子进程
  p.terminate()
  p.join()

运行结果:

子进程运行中,name= test,age=18 ,pid=45097...
{'m': 20}
子进程运行中,name= test,age=18 ,pid=45097...
{'m': 20}
子进程运行中,name= test,age=18 ,pid=45097...
{'m': 20}
子进程运行中,name= test,age=18 ,pid=45097...
{'m': 20}
子进程运行中,name= test,age=18 ,pid=45097...
{'m': 20}

5. 进程间不同享全局变量

# -*- coding:utf-8 -*-
from multiprocessing import Process
import os
import time
nums = [11, 22]
def work1():
  """子进程要执行的代码"""
  print("in process1 pid=%d ,nums=%s" % (os.getpid(), nums))
  for i in range(3):
    nums.append(i)
    time.sleep(1)
    print("in process1 pid=%d ,nums=%s" % (os.getpid(), nums))
def work2():
  """子进程要执行的代码"""
  print("in process2 pid=%d ,nums=%s" % (os.getpid(), nums))
if __name__ == '__main__':
  p1 = Process(target=work1)
  p1.start()
  p1.join()
  p2 = Process(target=work2)
  p2.start()

运行结果:

in process1 pid=11349 ,nums=[11, 22]
in process1 pid=11349 ,nums=[11, 22, 0]
in process1 pid=11349 ,nums=[11, 22, 0, 1]
in process1 pid=11349 ,nums=[11, 22, 0, 1, 2]
in process2 pid=11350 ,nums=[11, 22]

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python Paramiko模块的安装与使用详解
Nov 18 Python
基于python requests库中的代理实例讲解
May 07 Python
python中退出多层循环的方法
Nov 27 Python
python使用selenium登录QQ邮箱(附带滑动解锁)
Jan 23 Python
情人节快乐! python绘制漂亮玫瑰
Aug 18 Python
python3实现单目标粒子群算法
Nov 14 Python
python带参数打包exe及调用方式
Dec 21 Python
python中random.randint和random.randrange的区别详解
Sep 20 Python
python邮件中附加文字、html、图片、附件实现方法
Jan 04 Python
Pytest allure 命令行参数的使用
Apr 18 Python
python利用while求100内的整数和方式
Nov 07 Python
详解在OpenCV中如何使用图像像素
Mar 03 Python
Django Form and ModelForm的区别与使用
Dec 06 #Python
python 实现二维字典的键值合并等函数
Dec 06 #Python
python二分法查找算法实现方法【递归与非递归】
Dec 06 #Python
python二维键值数组生成转json的例子
Dec 06 #Python
python加载自定义词典实例
Dec 06 #Python
Python 词典(Dict) 加载与保存示例
Dec 06 #Python
python3 dict ndarray 存成json,并保留原数据精度的实例
Dec 06 #Python
You might like
关于Intype一些小问题的解决办法
2008/03/28 PHP
destoon实现调用图文新闻的方法
2014/08/21 PHP
教你php如何实现验证码
2016/01/20 PHP
PHP实现关键字搜索后描红功能示例
2019/07/03 PHP
PHP手机号码及邮箱正则表达式实例解析
2020/07/11 PHP
如何用javascript判断录入的日期是否合法
2007/01/08 Javascript
JavaScript操纵窗口的方法小结
2013/06/28 Javascript
js判断选择的时间是否大于今天的代码
2013/08/20 Javascript
js字符串转成JSON
2013/11/07 Javascript
javascript轻松实现当鼠标移开时已弹出子菜单自动消失
2013/12/29 Javascript
jquery插件tytabs.jquery.min.js实现渐变TAB选项卡效果
2015/08/25 Javascript
jQuery实现点击水纹波动动画
2016/04/10 Javascript
js实现千分符和保留几位小数的简单实例
2016/08/01 Javascript
在React中如何优雅的处理事件响应详解
2017/07/24 Javascript
webpack css加载和图片加载的方法示例
2018/09/11 Javascript
vue+springboot图片上传和显示的示例代码
2020/02/14 Javascript
Centos Python2 升级到Python3的简单实现
2016/06/21 Python
python2.7 mayavi 安装图文教程(推荐)
2017/06/22 Python
python 与服务器的共享文件夹交互方法
2018/12/27 Python
python实现五子棋小程序
2019/06/18 Python
python使用pip安装SciPy、SymPy、matplotlib教程
2019/11/20 Python
python如何实现DES加密
2020/09/21 Python
5分钟弄清楚html5的drag and drop(小结)
2019/04/10 HTML / CSS
请用Java实现列出某个目录下的所有文件
2013/09/23 面试题
JSF的标签库有哪些
2012/04/27 面试题
大学生求职简历的自我评价范文
2013/10/12 职场文书
杠杆的科学教学反思
2014/01/10 职场文书
工程招投标邀请书
2014/01/30 职场文书
超市采购员岗位职责
2014/02/01 职场文书
人民教师的自我评价分享
2014/02/21 职场文书
医院节能减排方案
2014/06/13 职场文书
法制教育演讲稿
2014/09/10 职场文书
2015小学音乐教师个人工作总结
2015/07/21 职场文书
同事离别感言
2015/08/04 职场文书
用python批量解压带密码的压缩包
2021/05/31 Python
浅谈音视频 pts dts基本概念及理解
2022/08/05 数码科技