multiprocessing模块

Posted zengsf

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了multiprocessing模块相关的知识,希望对你有一定的参考价值。

执行步骤;

  1. 需要将要做的事情封装成函数
  2. 使用multiprocessing提供的类Process创建进程对象
  3. 通过进程对象和Process初始化进程进行进程的设置,绑定函数
  4. 启动进程,会自动执行绑定的函数
  5. 完成进程的回收

函数:

  Process()
    功能: 创建进程对象
    参数: target : 要绑定的函数
    name : 给进程起的名称 (默认Process-1)
    args: 元组 用来给target函数位置传参
    kwargs : 字典 用来给target函数键值传参

  p.start()
    功能 : 启动进程
    * 自动运行terget绑定函数。此时进程才真正的被创建

  p.join([timeout])
    功能: 阻塞等待子进程退出
    参数: 超时时间

multiprocessing创建进程的特性:

  * 使用multiprocessing创建进程子进程同样复制父进程的全部内存空间,之后有自己独立的空间,执行上互不干扰
  * 子进程也是有自己特有的PID等资源
  * 如果不使用join回收可能会产生僵尸进程
  * 使用multiprocessing创建子进程,一般父进程功能就是创建子进程回收子进程,所有事件交给子进程完成

代码示例from multiprocessing import Processfrom time import sleep

import os

def th1():
    sleep(3)
    print("chifan")
    print(os.getppid(),"-----",os.getpid())
def th2():
    sleep(2)
    print("shuijiao")
    print(os.getppid(),"-----",os.getpid())
def th3():
    sleep(4)
    print("dadoudou")
    print(os.getppid(),"-----",os.getpid())

things= [th1,th2,th3]
process = []
for th in things:
    p = Process(target = th)
    process.append(p)
    p.start()
#循环回收进程
for i in process:
    i.join()

 

















以上是关于multiprocessing模块的主要内容,如果未能解决你的问题,请参考以下文章

multiprocessing模块

Python多进程 - subprocess & multiprocess

multiprocessing模块

有没有办法在嵌套函数或模块中使用 multiprocessing.pool ?

进程的创建-multiprocessing

multiprocessing模块创建进程