multiprocessing模块创建进程

72 阅读2分钟

multiprocessing模块创建进程

1.流程特点

  1. 将需要将子进程执行的事件封装为函数
  2. 通过模块的Process类创建进程对象,关联函数
  3. 可以通过进程对象设置进程信息及属性
  4. 通过进程对象调用start启动进程
  5. 通过进程对象调用join回收进程

2.基本接口使用

Process()

功能:创建进程对象

参数:

     target绑定要执行的目标函数
     args元组,用于给target函数位置传参
     kwargs字典,给target函数键值传参

p.start()

功能:启动进程

注意:启动进程此时target绑定函数开始执行,该函数作为 子进程执行内容,此时进程真正被创建

p.join([timeout])

功能:阻塞等待回收进程

参数:超时时间

可以防止僵尸进程的产生

import multiprocessing
import time


def fun():
    print("开始第一个进程")
    time.sleep(5)
    print("结束子进程")


if __name__ == '__main__':
    p = multiprocessing.Process(target=fun)

    p.start()
    time.sleep(3)
    print("父进程")
    p.join()

与socket相同,将父进程的内存全部复制到子进程中

  • 注意:
  • 使用multiprocessingt创建进程同样是子进程复制父进程空间代码段,父子进程运行互不影响。
  • 子进程只运行target绑定的函数部分,其余内容均是父进程执行内容。
  • multiprocessing中父进程往往只用来创建子进程回收子进程,具体事件由子进程完成。
  • multiprocessingt创建的子进程中无法使用标准输入。

其他属性

  • p.name进程名称
  • p.pid对应子进程的PID号
  • p.is alive0查看子进程是否在生命周期

p.daemon设置父子进程的退出关系

  • 如果设置为True则子进程会随父进程的退出而结束
  • 要求必须在start()前设置
  • 如果daemon设置成True通常就不会使用join()