让我们由浅到深----------深刻了解python中进程创建、使用、管理等等。。。。

37 阅读6分钟

import multiprocessing # 进程包

import time

1.work1

def work():

print("当前work:",os.getpid())

TODO 当前的进程名

print("work:",multiprocessing.current_process())

TODO 获取父进程

print("work的父进程是:",os.getppid())

for i in range(5):

print("work正在工作中.....")

time.sleep(0.2)

2.work2

def work2():

for i in range(5):

TODO 当前的进程名

print("work2:", multiprocessing.current_process())

TODO 获取父进程

print("work2的父进程是:", os.getppid())

print("当前work2:", os.getpid())

print("work2正在工作中......")

time.sleep(0.2)

if name=="main": # TODO 主进程

print("main:",os.getpid())

TODO 两个子进程

work_process=multiprocessing.Process(target=work,name="work1Process")

work2_process=multiprocessing.Process(target=work2)

启动子进程任务

work_process.start()

work2_process.start()

multiprocessing.Process()

运行结果:

main: 12700

当前work:work2: 31648

work:

work的父进程是: 12700

work2的父进程是: work正在工作中.....12700

当前work2: 31856

work2正在工作中......

work正在工作中.....

work2:

work2的父进程是: 12700

当前work2: 31856

work2正在工作中......

work正在工作中.....

work2:

work2的父进程是: 12700

当前work2: 31856

work2正在工作中......

work正在工作中.....

work2:

work2的父进程是: 12700

当前work2: 31856

work2正在工作中......

work正在工作中.....

work2:

work2的父进程是: 12700

当前work2: 31856

work2正在工作中......

Process finished with exit code 0

我们可以清晰地发现进程的名字和当前进程的父进程。****work1ProcessProcess-2,**前者是我们自己起的名字,如果没有起会默认为Process-1进程一旦分配除非遇到内存限制,资源不够等特殊情况(程序不能继续执行下去),进程会一直运行下去且进程名不变。也就是说进程名会和我们的名字一样,出生到死亡一辈子都是这个名字,中途改名对应的就是计算机所发生的特殊情况(内存不够、程序出错等原因)


**

进程执行带有参数的任务


**

进程执行传参操作,字典、元组等为后面大型项目做铺垫可能现在的项目单个进程和多个进程还没有很好的体现,但是后面随着项目规模的变大,你会很好的发现单进程和多进程的区别。所以了解进程十分重要

元组传参

import os # 一般用于文件处理

import multiprocessing # 进程包

import time

1.work1

def work(count,number):

print("当前work:",os.getpid())

TODO 当前的进程名

print("work:",multiprocessing.current_process())

TODO 获取父进程

print("work的父进程是:",os.getppid())

for i in range(5):

print("work正在工作中.....")

time.sleep(0.2)

2.work2

def work2(count,number):

for i in range(5):

# TODO 当前的进程名

print("work2:", multiprocessing.current_process())

# TODO 获取父进程

print("work2的父进程是:", os.getppid())

print("当前work2:", os.getpid())

print("work2正在工作中......")

time.sleep(0.2)

if name=="main": # TODO 主进程

print("main:",os.getpid())

TODO 两个子进程

work_process=multiprocessing.Process(target=work,args=(5,10))

work2_process=multiprocessing.Process(target=work2,kwargs={"count":5,"number":10})

启动子进程任务

work_process.start()

work2_process.start()

multiprocessing.Process()

运行结果:

main: 11896

当前work: 23728

work:

work的父进程是: 11896

work正在工作中.....

work正在工作中.....

work正在工作中.....

work正在工作中.....

work正在工作中.....

元组传参就是主进程将数据以元组的方式传递给子进程,类似于python中调用一个函数,通过元组的方式传参。不太理解的可以去了解一下Python的传参过程,很重要,想要掌握python就必须要掌握它。

元组格式 (1,5,3)、(“小红”,“小花”,“18”)、(2,)

注意:一个元素是要加一个逗号

python中的元素交换

a,b=b,a

这样就可以交换a,b的值


字典传参

import os # 一般用于文件处理

import multiprocessing # 进程包

import time

1.work1

def work(count,number):

print("当前work:",os.getpid())

# TODO 当前的进程名

print("work:",multiprocessing.current_process())

# TODO 获取父进程

print("work的父进程是:",os.getppid())

for i in range(5):

print("work正在工作中.....")

time.sleep(0.2)

2.work2

def work2(count,number):

for i in range(5):

TODO 当前的进程名

print("work2:", multiprocessing.current_process())

TODO 获取父进程

print("work2的父进程是:", os.getppid())

print("当前work2:", os.getpid())

print("work2正在工作中......")

time.sleep(0.2)

if name=="main": # TODO 主进程

print("main:",os.getpid())

TODO 两个子进程

work_process=multiprocessing.Process(target=work,args=(5,10))

work2_process=multiprocessing.Process(target=work2,kwargs={"count":5,"number":10})

启动子进程任务

work_process.start()

work2_process.start()

time.sleep(0.2) 休息0.2s,如果不休息0.2s你会发现太顺畅,结果一下子就出来了,休息0.2s可以更好地看清楚进程运行

运行结果:

main: 18372

work2:

work2的父进程是: 18372

当前work2: 13016

work2正在工作中......

work2:

work2的父进程是: 18372

当前work2: 13016

work2正在工作中......

work2:

work2的父进程是: 18372

当前work2: 13016

work2正在工作中......

work2:

work2的父进程是: 18372

当前work2: 13016

work2正在工作中......

work2:

work2的父进程是: 18372

当前work2: 13016

work2正在工作中......

Process finished with exit code 0

字典传参就是主进程将数据以字典的方式传递给子进程,类似于python中调用一个函数,通过字典的方式传参。不太理解的可以去了解一下Python的传参过程,很重要,想要掌握python就必须要掌握它。 **字典和元组都是python常见的两种格式,其中字典是以键对值存在的,就是一把药匙一个门,键就是药匙,值就是门,可能一把药匙可以开n个门,但是一个门不可能同时存在多个药匙。也就是说,键不可以重复,是唯一的,但是值可以重复。所以通常可以通过键去提取值。**上文提点传参就是将数据以字典的形式传出去。

只要是进程你反复运行结果都是不一样的,因为进程是系统随机分配的,基本上不可能重复,如果你反复运行是重复的,恭喜你,你可以买彩票了,别忘了叫上我。

注意:

守护主进程

deamo = True

子进程销毁

terminate

退出进程

exit()

常用属性

name:当前进程起别名,默认为Process-1,依次递增

实例方法:

start()

启动子进程实例(创建子进程)

join()

等待子进程执行结束

terminate()

在这里插入图片描述

感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:

① 2000多本Python电子书(主流和经典的书籍应该都有了)

② Python标准库资料(最全中文版)

③ 项目源码(四五十个有趣且经典的练手项目及源码)

④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)

⑤ Python学习路线图(告别不入流的学习)

了解详情:docs.qq.com/doc/DSnl3ZG…