gpt4 book ai didi

linux - Python3 多处理 Windows 和 Linux

转载 作者:太空宇宙 更新时间:2023-11-04 12:09:23 26 4
gpt4 key购买 nike

我有一个我使用的单例类。我在我的主线程上创建了这个类的一个实例。

我创建了一些多进程,对我来说似乎合乎逻辑(由于 GIL 的工作方式)是,当我在那里实例化同一个类时,它是一个新实例,它看不到在我的主线程中实例化的那个。

但如果我在 Linux 上做同样的事情,当创建我的多进程并实例化我的类时,它会返回指向在我的主线程中创建的实例的指针,因此可以看到来自那个实例的数据。

这可能涉及到一些我不了解的 Linux 和 Windows 中线程的基本原理。但是,如果有人可以帮助我简要地理解或指出我可以在哪里阅读它

问候

编辑

在 Windows 上:

def child_process_function():
SingletonThread = instantiate_singleton() <-- This will be a new instance

do_work()

SingletonMain = instantiate_singleton()
process = multiprocessing.Process(target=child_process_function)
process.start()

在 Linux 上

def child_process_function():
SingletonThread = instantiate_singleton() <-- This will contain the data from the SingletonMain.

do_work()

SingletonMain = instantiate_singleton()
process = multiprocessing.Process(target=child_process_function)
process.start()

现在,在阅读您的链接后,Linux SingletonThread 并未指向 SingletonMain,因为我起初认为它只是复制了数据。但是我的问题是,因为数据没有在 Windows 上复制,所以我通过队列发送数据(数据一直在变化,所以这是所需的方法)。但是类上有一个覆盖 block (它包含设置),所以如果数据已经存在,就像在 Linux 上一样,我会在类上得到并写入错误。但是添加。

import multiprocessing as mp
mp.set_start_method('spawn')

解决了我的问题。

最佳答案

当生成一个新进程时,UNIX 操作系统使用 fork 策略从字面上复制父进程,以便子进程拥有父进程的内存和资源的精确副本。 内存是复制的,不是共享的。因此,应用于子单例实例的更改不会被父实例看到,反之亦然。

由于现代操作系统中虚拟内存的管理方式,您会被看到“相同的指针”这一事实所误导。您看到的指针是相同的,因为它们从相同的偏移量开始,但它们实际上属于不同的内存页。我给了类似的解释here .

您可以在 multiprocessing 模块中阅读更多关于进程启动机制的信息 documentation .

关于linux - Python3 多处理 Windows 和 Linux,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49489379/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com