J'essaie d'utiliser multiprocessing
la Pool.map()
fonction de pour répartir le travail simultanément. Lorsque j'utilise le code suivant, cela fonctionne bien:
import multiprocessing
def f(x):
return x*x
def go():
pool = multiprocessing.Pool(processes=4)
print pool.map(f, range(10))
if __name__== '__main__' :
go()
Cependant, lorsque je l'utilise dans une approche plus orientée objet, cela ne fonctionne pas. Le message d'erreur qu'il donne est:
PicklingError: Can't pickle <type 'instancemethod'>: attribute lookup
__builtin__.instancemethod failed
Cela se produit lorsque ce qui suit est mon programme principal:
import someClass
if __name__== '__main__' :
sc = someClass.someClass()
sc.go()
et voici ma someClass
classe:
import multiprocessing
class someClass(object):
def __init__(self):
pass
def f(self, x):
return x*x
def go(self):
pool = multiprocessing.Pool(processes=4)
print pool.map(self.f, range(10))
Quelqu'un sait-il quel pourrait être le problème ou comment y remédier facilement?
PicklingError: Can't pickle <class 'function'>: attribute lookup builtins.function failed