百木园-与人分享,
就是让自己快乐。

Python 进程 Process 模块 - Python零基础入门教程

目录

  • 一.Python 进程 Process 简介
  • 二.Python 进程 Process 模块
  • 三.Python 进程 Process 函数介绍
  • 四.Python 进程 Process 使用
  • 五.Python 进程 Process 小窍门
  • 六.猜你喜欢

零基础 Python 学习路线推荐 : Python 学习目录 >> Python 基础入门

一.Python 进程 Process 简介

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

二.Python 进程 Process 模块

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

# !usr/bin/env python
# -*- coding:utf-8 _*-
\"\"\"
@Author:猿说编程
@Blog(个人博客地址): www.codersrc.com
@File:Python 进程 Process 模块.py
@Time:2021/05/06 07:37
@Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累!

\"\"\"

# 导入进程模块
from multiprocessing import Process

\'\'\'
参数介绍:
group — 参数未使用,默认值为None;
target — 表示调用对象,即子进程要执行的任务(函数名字);
args — 子进程对应函数的参数,并且类型是元组tuple;
kwargs — 子进程对应函数的参数,并且类型是字典dict,如kwargs = {‘name’:Jack, ‘age’:18};
name — 子进程名称;

返回值:返回进程实例对象;
\'\'\'

# 创建进程
p = Process(group=None, target=None, name=None, args=(), kwargs={})

三.Python 进程 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 字符的字符串。这个键的用途是设计涉及网络连接的底层进程间的通信提供安全性,这类连接只有在具有相同身份验证才能成功;

四.Python 进程 Process 使用

# !usr/bin/env python
# -*- coding:utf-8 _*-
\"\"\"
@Author:猿说编程
@Blog(个人博客地址): www.codersrc.com
@File:Python 进程 Process 模块.py
@Time:2021/05/06 07:37
@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 进程 Process 小窍门

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

# !usr/bin/env python
# -*- coding:utf-8 _*-
\"\"\"
@Author:猿说编程
@Blog(个人博客地址): www.codersrc.com
@File:Python 进程 Process 模块.py
@Time:2021/05/06 07:37
@Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累!

\"\"\"

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

关于进程 Process 创建就介绍到这里,不知道大家发现没有,进程 Process 的创建和线程 threading 的创建非常相似,那么 Python 进程和线程到底又有什么区别呢?关于 Python 进程和线程的区别请参考:Python 进程 Process 与线程 threading 的区别

六.猜你喜欢

  • Python 条件推导式
  • Python 列表推导式
  • Python 字典推导式
  • Python 函数声明和调用
  • Python 不定长参数 *argc/**kargcs
  • Python 匿名函数 lambda
  • Python return 逻辑判断表达式
  • Python 字符串/列表/元组/字典之间的相互转换
  • Python 局部变量和全局变量
  • Python type 函数和 isinstance 函数区别
  • Python is 和 == 区别
  • Python 可变数据类型和不可变数据类型
  • Python 浅拷贝和深拷贝
  • Python 文件读写操作
  • Python 异常处理
  • Python 模块 import
  • Python __name__ == ‘__main__’详细解释
  • Python 线程创建和传参
  • Python 线程互斥锁 Lock
  • Python 线程时间 Event
  • Python 线程条件变量 Condition
  • Python 线程定时器 Timer
  • Python 线程信号量 Semaphore
  • Python 线程障碍对象 Barrier
  • Python 线程队列 Queue – FIFO
  • Python 线程队列 LifoQueue – LIFO
  • Python 线程优先队列 PriorityQueue
  • Python 线程池 ThreadPoolExecutor(一)
  • Python 线程池 ThreadPoolExecutor(二)
  • Python 进程 Process 模块
  • Python 进程 Process 与线程 threading 区别
  • Python 进程间通信 Queue / Pipe
  • 未经允许不得转载:猿说编程 » Python 进程 Process 模块

    本文由博客 - 猿说编程 猿说编程 发布!

    来源:https://www.cnblogs.com/shuopython/p/14948550.html
    图文来源于网络,如有侵权请联系删除。

    未经允许不得转载:百木园 » Python 进程 Process 模块 - Python零基础入门教程

    相关推荐

    • 暂无文章