小编Cry*_*ina的帖子

多处理 fork() 与 spawn()

我正在阅读python 文档中对两者的描述:

产卵

父进程启动一个新的 python 解释器进程。子进程将只继承运行进程对象 run() 方法所需的资源。特别是,父进程中不必要的文件描述符和句柄将不会被继承。与使用 fork 或 forkserver 相比,使用此方法启动进程相当慢。[在 Unix 和 Windows 上可用。Windows 和 macOS 上的默认设置。]

叉子

父进程使用 os.fork() 来派生 Python 解释器。子进程在开始时实际上与父进程相同。父进程的所有资源都由子进程继承。请注意,安全地分叉多线程进程是有问题的。[仅在 Unix 上可用。Unix 上的默认设置。]

我的问题是:

  1. 是不是分叉更快了,因为它不会尝试识别要复制的资源?
  2. 是不是因为 fork 复制了所有内容,与 spawn() 相比,它会“浪费”更多资源吗?

python fork multiprocessing spawn python-multiprocessing

18
推荐指数
2
解决办法
6127
查看次数