我有一个名为 Experiment 的课程和另一个名为 Case 的课程。一项实验由许多个案组成。请参阅下面的类定义,
from multiprocessing import Process
class Experiment (object):
def __init__(self, name):
self.name = name
self.cases = []
self.cases.append(Case('a'))
self.cases.append(Case('b'))
self.cases.append(Case('c'))
def sr_execute(self):
for c in self.cases:
c.setVars(6)
class Case(object):
def __init__(self, name):
self.name = name
def setVars(self, var):
self.var = var
在我的实验课中,我有一个名为 sr_execute 的函数。此函数显示所需的行为。我有兴趣解析所有案例并为每个案例设置一个属性。当我运行以下代码时,
if __name__ == '__main__':
#multiprocessing.freeze_support()
e = Experiment('exp')
e.sr_execute()
for c in e.cases: print c.name, c.var
我明白了,
a 6
b 6
c 6
这是期望的行为。
但是,我想使用多处理并行执行此操作。为此,我在实验类中添加了一个 mp_execute() 函数,
def mp_execute(self):
processes = []
for c in self.cases:
processes.append(Process(target= c.setVars, args = (6,)))
[p.start() for p in processes]
[p.join() for p in processes]
但是,这不起作用。当我执行以下操作时,
if __name__ == '__main__':
#multiprocessing.freeze_support()
e = Experiment('exp')
e.mp_execute()
for c in e.cases: print c.name, c.var
我得到一个错误,
AttributeError: 'Case' object has no attribute 'var'
显然,我无法使用多处理设置类属性。
任何线索是怎么回事,