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利用flask sqlalchemy实现分页效果
Aug 02 Python
python通过百度地图API获取某地址的经纬度详解
Jan 28 Python
Python进阶之递归函数的用法及其示例
Jan 31 Python
python selenium 对浏览器标签页进行关闭和切换的方法
May 21 Python
在Python中实现替换字符串中的子串的示例
Oct 31 Python
利用anaconda保证64位和32位的python共存
Mar 09 Python
django 简单实现登录验证给你
Nov 06 Python
打包PyQt5应用时的注意事项
Feb 14 Python
python 实现图片修复(可用于去水印)
Nov 19 Python
用Python 执行cmd命令
Dec 18 Python
python之随机数函数的实现示例
Dec 30 Python
Python批量将csv文件转化成xml文件的实例
May 10 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
中国收音机工业发展史
2021/03/02 无线电
说说PHP的autoLoad自动加载机制
2012/09/27 PHP
PHP随机数 C扩展随机数
2016/05/04 PHP
php 查找数组元素提高效率的方法详解
2017/05/05 PHP
JS判断文本框内容改变事件的简单实例
2014/03/07 Javascript
js动态改变select选择变更option的index值示例
2014/07/10 Javascript
node.js中的fs.exists方法使用说明
2014/12/17 Javascript
js实现浮动在网页右侧的简洁QQ在线客服代码
2015/09/04 Javascript
js获取当前年月日-YYYYmmDD格式的实现代码
2016/06/01 Javascript
JavaScript中push(),join() 函数 实例详解
2016/09/06 Javascript
解决Window10系统下Node安装报错的问题分析
2016/12/13 Javascript
JavaScript中常见的八个陷阱总结
2017/06/28 Javascript
使用vue-router为每个路由配置各自的title
2018/07/30 Javascript
详解如何在Angular优雅编写HTTP请求
2018/12/05 Javascript
深入koa-bodyparser原理解析
2019/01/16 Javascript
node.js 基于cheerio的爬虫工具的实现(需要登录权限的爬虫工具)
2019/04/10 Javascript
JavaScript实现单英文金山打字通
2020/07/24 Javascript
Vue 中 filter 与 computed 的区别与用法解析
2019/11/21 Javascript
JavaScript Html实现移动端红包雨功能页面
2021/01/10 Javascript
python实现sublime3的less编译插件示例
2014/04/27 Python
一个小示例告诉你Python语言的优雅之处
2014/07/04 Python
使用Python编写vim插件的简单示例
2015/04/17 Python
用Python脚本来删除指定容量以上的文件的教程
2015/05/04 Python
python实现批量处理将图片粘贴到另一张图片上并保存
2019/12/12 Python
Python通过VGG16模型实现图像风格转换操作详解
2020/01/16 Python
python 实现仿微信聊天时间格式化显示的代码
2020/04/17 Python
Python3 Tensorlfow:增加或者减小矩阵维度的实现
2020/05/22 Python
使用tensorflow实现VGG网络,训练mnist数据集方式
2020/05/26 Python
python中加背景音乐如何操作
2020/07/19 Python
使用python库xlsxwriter库来输出各种xlsx文件的示例
2020/09/01 Python
10个顶级Python实用库推荐
2021/03/04 Python
以设计师精品品质提供快速时尚:PopJulia
2018/01/09 全球购物
游戏商店:Eneba
2020/04/25 全球购物
新课培训心得体会
2014/09/03 职场文书
公司领导班子民主生活会对照检查材料
2014/10/02 职场文书