Python 进程的创建 - multiprocessing

2024-08-21 04:58

本文主要是介绍Python 进程的创建 - multiprocessing,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

仅用学习参考,转载请注明出处

进程的创建-multiprocessing

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

2个while循环一起执行,同时两人循环买烟

[root@server01 process]# vim test.py # -*- coding:utf-8 -*-
from multiprocessing import Process
import timedef bug_ciggite():while True:print("第一个人:胖子老板来包蓝利群")time.sleep(1)def main():# 第一个人开启一个子进程来执行循环买烟的操作   p = Process(target=bug_ciggite)p.start()# 第二个人来跟胖子老板买烟while True:print("第二个人:胖子老板来包芙蓉王")time.sleep(1)if __name__ == "__main__":main()

执行如下:

[root@server01 process]# python test.py 
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群

从上面的执行来看,两个while循环买烟的操作并没有被阻塞,例如不需要第一个循环执行完毕,才能执行第二个循环。而是直接可以两个循环同时进行。

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

进程pid

打印上面代码的主进程和子进程的pid看看。

# -*- coding:utf-8 -*-
from multiprocessing import Process
import time
import osdef bug_ciggite():while True:print("第一个人:胖子老板来包蓝利群")print("打印子进程的pid=%d" % os.getpid())time.sleep(1)def main():print("打印主进程的pid=%d" % os.getpid())# 第一个人开启一个子进程来执行循环买烟的操作   p = Process(target=bug_ciggite)p.start()# 第二个人来跟胖子老板买烟while True:print("第二个人:胖子老板来包芙蓉王")time.sleep(1)if __name__ == "__main__":main()

执行如下:

[root@server01 process]# python test.py 
打印主进程的pid=1864
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
打印子进程的pid=1865
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
打印子进程的pid=1865
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群

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(进程号)

给子进程指定的函数传递参数 - 买多少钱的烟

# -*- coding:utf-8 -*-
from multiprocessing import Process
import time
import osdef bug_ciggite(name,price,**kwargs):while True:print("第一个人:胖子老板来包蓝利群")print("打印子进程的pid=%d" % os.getpid())print("买包%d的%s" % (price,name))print(kwargs)time.sleep(1)def main():print("打印主进程的pid=%d" % os.getpid())   # 第一个人开启一个子进程来执行循环买烟的操作   p = Process(target=bug_ciggite,args=('蓝利群',17),kwargs={"m":20})p.start()# 第二个人来跟胖子老板买烟while True:print("第二个人:胖子老板来包芙蓉王")time.sleep(1)if __name__ == "__main__":main()

执行如下:

[root@server01 process]# python test.py 
打印主进程的pid=1904
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
打印子进程的pid=1905
买包17的蓝利群
{'m': 20}
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
打印子进程的pid=1905
买包17的蓝利群
{'m': 20}
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
打印子进程的pid=1905
买包17的蓝利群
{'m': 20}
第二个人:胖子老板来包芙蓉王
第一个人:胖子老板来包蓝利群
打印子进程的pid=1905
买包17的蓝利群
{'m': 20}

进程间不共享全局变量

定义一个全局变量,使用两个进程分别修改,然后分别打印,查看是否相同。
例如:定义一包烟的名称,两个进程,一个修改,一个不修改,分开打印。

# -*- coding:utf-8 -*-
from multiprocessing import Process
import time
import osciggite_name = "蓝利群"def bug_ciggite1():ciggite_name = '芙蓉王'for i in range(3):print("第一个人:胖子老板来包%s" % ciggite_name )time.sleep(1)def bug_ciggite2():for i in range(3):print("第二个人: 胖子老板来包 %s" % ciggite_name)time.sleep(1)def main():print("打印主进程的pid=%d" % os.getpid())   print("主进程开始执行:我要买%s" % ciggite_name)# 第一个人开启一个子进程来执行循环买烟的操作   p1 = Process(target=bug_ciggite1)p1.start()# 第二个人开启子进程买烟p2 = Process(target=bug_ciggite2)p2.start()print("主进程结束执行:我要买%s" % ciggite_name)if __name__ == "__main__":main()

执行如下:

[root@server01 process]# python test.py 
打印主进程的pid=2014
主进程开始执行:我要买蓝利群
主进程结束执行:我要买蓝利群
第一个人:胖子老板来包芙蓉王
第二个人: 胖子老板来包 蓝利群
第二个人: 胖子老板来包 蓝利群
第一个人:胖子老板来包芙蓉王
第一个人:胖子老板来包芙蓉王
第二个人: 胖子老板来包 蓝利群
[root@server01 process]# 

可以从结果中看出,第一个进程修改了ciggite_name为芙蓉王,但是却不影响主进程和子进程的值,依然是蓝利群。
说明子进程并不能共享修改全局变量,这一点与线程是有区别的。

13423234-7907ae6344e86e8a.png

关注微信公众号,回复【资料】、Python、PHP、JAVA、web,则可获得Python、PHP、JAVA、前端等视频资料。

这篇关于Python 进程的创建 - multiprocessing的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092187

相关文章

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Python中4大日志记录库比较的终极PK

《Python中4大日志记录库比较的终极PK》日志记录框架是一种工具,可帮助您标准化应用程序中的日志记录过程,:本文主要介绍Python中4大日志记录库比较的相关资料,文中通过代码介绍的非常详细,... 目录一、logging库1、优点2、缺点二、LogAid库三、Loguru库四、Structlogphp

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

Python海象运算符:=的具体实现

《Python海象运算符:=的具体实现》海象运算符又称​​赋值表达式,Python3.8后可用,其核心设计是在表达式内部完成变量赋值并返回该值,从而简化代码逻辑,下面就来详细的介绍一下如何使用,感兴趣... 目录简介​​条件判断优化循环控制简化​推导式高效计算​正则匹配与数据提取​性能对比简介海象运算符