2017-10-16 19 views
1

Je ne sais pas pourquoi, mais j'obtiens cette erreur étrange chaque fois que j'essaie de passer à la méthode d'un objet de classe personnalisé partagé par un objet partagé. version Python: 3.6.3Gestionnaires multitraitement et classes personnalisées

code:

from multiprocessing.managers import SyncManager 

class MyManager(SyncManager): pass 
class MyClass: pass 

class Wrapper: 
    def set(self, ent): 
     self.ent = ent 

MyManager.register('MyClass', MyClass) 
MyManager.register('Wrapper', Wrapper) 

if __name__ == '__main__': 
    manager = MyManager() 
    manager.start() 

    try: 
     obj = manager.MyClass() 
     lst = manager.list([1,2,3]) 

     collection = manager.Wrapper() 
     collection.set(lst) # executed fine 
     collection.set(obj) # raises error 
    except Exception as e: 
     raise 

Erreur:

--------------------------------------------------------------------------- 
Traceback (most recent call last): 
    File "D:\Program Files\Python363\lib\multiprocessing\managers.py", line 228, in serve_client 
    request = recv() 
    File "D:\Program Files\Python363\lib\multiprocessing\connection.py", line 251, in recv 
    return _ForkingPickler.loads(buf.getbuffer()) 
    File "D:\Program Files\Python363\lib\multiprocessing\managers.py", line 881, in RebuildProxy 
    return func(token, serializer, incref=incref, **kwds) 
TypeError: AutoProxy() got an unexpected keyword argument 'manager_owned' 
--------------------------------------------------------------------------- 

Quel est le problème ici?

Répondre

1

Solution temporaire trouvée here. J'ai réussi à le réparer en ajoutant le mot-clé nécessaire à l'initialiseur d'AutoProxy dans multiprocessing \ managers.py Cependant, je ne sais pas si ce kwarg est responsable de quoi que ce soit.