Почему multiprocessing.Process не может вызвать метод из экземпляра объекта? не могу понять эту проблему с рассолом

Я хотел бы вызвать метод из экземпляра объекта как подпроцесс. Я использую Python 3.6 на Windows 10.

давайте создадим простой класс:

class A:
     def __init__(self):
         self.a = "A"
     def run(self):
         print("Hello World")

Проверь это

>>> a = A()
>>> a.run()
Hello World

Затем вызовите метод запуска через MP

from multiprocessing import Process

if __name__ == "__main__":
    p = Process(target=a.run)
    p.start()

И тогда у меня есть следующая ошибка:

Traceback (most recent call last):
File "<string>", line 1, in <module>   
File "C:\Users\Synerlink\AppData\Local\Programs\Python\Python36\lib\multiprocessing\spawn.py", line 105, in spawn_main
     exitcode = _main(fd)
File "C:\Users\Synerlink\AppData\Local\Programs\Python\Python36\lib\multiprocessing\spawn.py", line 115, in _main 
     self = reduction.pickle.load(from_parent) 
AttributeError: Can't get attribute 'A' on <module '__main__' (built-in)>

Может ли кто-нибудь объяснить мне, откуда это взялось, если есть способ сделать это?

Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
0
0
31
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Не уверен, как выглядит ваш полный код, но это просто работает.

from multiprocessing import Process


class A:
    def __init__(self):
        self.a = 'A'

    def run(self):
        print('Hello World')

if __name__ == '__main__':
    a = A()
    p = Process(target=a.run)
    p.start()

Другие вопросы по теме