multiprocessing 模块创建进程
进程创建方法
-
流程特点
【1】 将需要子进程执行的事件封装为函数
【2】 通过模块的Process类创建进程对象,关联函数
【3】 可以通过进程对象设置进程信息及属性
【4】 通过进程对象调用start启动进程
【5】 通过进程对象调用join回收进程 -
基本接口使用
Process()
功能 : 创建进程对象
参数 : target 绑定要执行的目标函数
args 元组,用于给target函数位置传参
kwargs 字典,给target函数键值传参
p.start()
功能 : 启动进程
注意:启动进程此时target绑定函数开始执行,该函数作为子进程执行内容,此时进程真正被创建
p.join([timeout])
功能:阻塞等待回收进程
参数:超时时间
注意
- 使用multiprocessing创建进程同样是子进程复制父进程空间代码段,父子进程运行互不影响。
- 子进程只运行target绑定的函数部分,其余内容均是父进程执行内容。
- multiprocessing中父进程往往只用来创建子进程回收子进程,具体事件由子进程完成。
- multiprocessing创建的子进程中无法使用标准输入
'''
multiprocessing进程示例
'''
import multiprocessing as mp
from time import sleep
def fun():
print("子进程开始执行")
sleep(3)
print("子进程执行完毕")
print("父进程开始执行")
# 创建进程对象
p = mp.Process(target=fun)
# 启动进程
p.start()
# 回收进程
p.join()
print("父进程执行完毕")
'''
批量回收子进程
'''
import multiprocessing as mp
from time import sleep
def th1():
sleep(1)
print("吃饭")
def th2():
sleep(2)
print("睡觉")
def th3():
sleep(3)
print("打豆豆")
things = [th1, th2, th3]
jobs = []
for th in things:
p = mp.Process(target = th)
jobs.append(p)
p.start()
for i in jobs:
i.join()
'''
给进程函数传参
'''
from multiprocessing import Process
from time import sleep
def worker(sec,name):
for i in range(3):
sleep(sec)
print("I`m %s"%name)
print("I`m working......")
p = Process(target=worker,args=(2,'Xiaoming'))
p = Process(target=worker,kwargs={'name':"Abby",'s':2})
p.start()
p.join()
- 进程对象属性
p.name 进程名称
p.pid 对应子进程的PID号
p.is_alive() 查看子进程是否在生命周期
p.daemon 设置父子进程的退出关系
- 如果设置为True则子进程会随父进程的退出而结束
- 要求必须在start()前设置
- 如果daemon设置成True 通常就不会使用 join()
'''
进程对象属性
'''
from multiprocessing import Process
from time import sleep,ctime
def tm():
for i in range(3):
sleep(2)
print(ctime())
p = Process(target = tm,name = "Tedu")
# 子进程随父进程退出
p.daemon = True
p.start()
print("Name:",p.name) # 获取名称
print("PID:",p.pid) # 获取PID
print("is Alive:",p.is_alive()) # 是否在生命周期