python-多任务编程-进程
2021/8/20 7:07:25
本文主要是介绍python-多任务编程-进程,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
-
1.1进程的概念
-
进程是操作系统进行资源分配的基本单位。
-
进程是Python程序中实现多任务的一种方式
1.2多进程的使用
-
导入进程包
-
import multiprocessing
-
-
创建子进程并指定执行的任务
-
sub_process = multiprocessing.Process (target=任务名)
-
-
启动进程执行任务
-
sub_process.start()
-
Process(group,target,name,args,kwargs)** - group:指定进程组,目前只能使用None - target:执行的目标任务名 - name:进程名字 - args:以元组方式给执行任务传参 - kwargs: 以字典方式给执行任务传参 **Process创建的实例对象的常用方法:** - start():启动子进程实例(创建子进程) - join():等待子进程执行结束 - terminate():不管任务是否完成,立即终止子进程 **Process创建的实例对象的常用属性:** name:当前进程的别名,默认为Process-N,N为从1开始递增的整数
-
1.3获取进程编号
-
获取当前进程编号
-
os.getpid()
-
-
获取当前父进程编号
-
os.getppid()
-
-
获取进程编号可以查看父子进程的关系
-
1.4进程执行带有参数的任务
-
进程执行任务并传参有两种方式:
-
元组方式传参(args): 元组方式传参一定要和参数的顺序保持一致。
-
字典方式传参(kwargs): 字典方式传参字典中的key一定要和参数名保持一致。
-
1.5进程的注意点
-
进程之间不共享全局变量
-
创建子进程会对主进程资源进行拷贝,也就是说子进程是主进程的一个副本,好比是一对双胞胎,之所以进程之间不共享全局变量,是因为操作的不是同一个进程里面的全局变量,只不过不同进程里面的全局变量名字相同而已。
-
-
主进程会等待所有的子进程执行结束再结束
-
为了保证子进程能够正常的运行,主进程会等所有的子进程执行完成以后再销毁,设置守护主进程的目的是主进程退出子进程销毁,不让主进程再等待子进程去执行。
-
设置守护主进程方式: 子进程对象.daemon = True
-
销毁子进程方式: 子进程对象.terminate()
-
-
import multiprocessing import time # 定义进程所需要执行的任务 def task(): for i in range(10): print("任务执行中...") time.sleep(0.2) if __name__ == '__main__': # 创建子进程 sub_process = multiprocessing.Process(target=task) # 设置守护主进程,主进程退出子进程直接销毁,子进程的生命周期依赖与主进程 # sub_process.daemon = True sub_process.start() time.sleep(0.5) print("over") # 让子进程销毁 sub_process.terminate() exit() # 总结: 主进程会等待所有的子进程执行完成以后程序再退出 # 如果想要主进程退出子进程销毁,可以设置守护主进程或者在主进程退出之前让子进程销毁
这篇关于python-多任务编程-进程的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-24Python编程入门指南
- 2024-12-24Python编程基础入门
- 2024-12-24Python编程基础:变量与数据类型
- 2024-12-23使用python部署一个usdt合约,部署自己的usdt稳定币
- 2024-12-20Python编程入门指南
- 2024-12-20Python编程基础与进阶
- 2024-12-19Python基础编程教程
- 2024-12-19python 文件的后缀名是什么 怎么运行一个python文件?-icode9专业技术文章分享
- 2024-12-19使用python 把docx转为pdf文件有哪些方法?-icode9专业技术文章分享
- 2024-12-19python怎么更换换pip的源镜像?-icode9专业技术文章分享