一种方法是让计算类(simulation)成为Process的子类。正确初始化后,该类的实例将在单独的进程中运行,您可以根据需要从列表中设置一组实例。
下面是一个例子,基于您在上面所写的内容:import multiprocessing
import os
import random
class simulation(multiprocessing.Process):
def __init__(self, name):
# must call this before anything else
multiprocessing.Process.__init__(self)
# then any other initialization
self.name = name
self.number = 0.0
sys.stdout.write('[%s] created: %f\n' % (self.name, self.number))
def run(self):
sys.stdout.write('[%s] running ... process id: %s\n'
% (self.name, os.getpid()))
self.number = random.uniform(0.0, 10.0)
sys.stdout.write('[%s] completed: %f\n' % (self.name, self.number))
然后列出一个对象列表,并以循环开始每个对象:sim_list = []
sim_list.append(simulation('foo'))
sim_list.append(simulation('bar'))
for sim in sim_list:
sim.start()
运行此命令时,应看到每个对象在其自己的进程中运行。不要忘记在初始化类之前,首先调用Process.__init__(self)。
显然,在这个例子中我没有包含任何进程间通信;如果您的情况需要,您必须添加它(从您的问题中不清楚您是否需要它)。
这种方法对我很有效,我不知道有什么缺点。如果有人知道我忽略的隐患,请告诉我。
我希望这能有帮助。