在下面的代码中,如何使Starter
对象能够读取gen.vals
? 这似乎是一个不同的对象被创建,其状态得到更新,但绝不Starter
知道这事。此外,该解决方案将如何申请self.vals
是一本字典,或任何其他类型的对象?跨进程共享对象状态?
import multiprocessing
import time
class Generator(multiprocessing.Process):
def __init__(self):
self.vals = []
super(Generator, self).__init__()
def run(self):
i = 0
while True:
time.sleep(1)
self.vals.append(i)
print 'In Generator ', self.vals # prints growing list
i += 1
class Starter():
def do_stuff(self):
gen = Generator()
gen.start()
while True:
print 'In Starter ', gen.vals # prints empty list
time.sleep(1)
if __name__ == '__main__':
starter = Starter()
starter.do_stuff()
输出:
In Starter []
In Starter []
In Generator [0]
In Starter []
In Generator [0, 1]
In Starter []
In Generator [0, 1, 2]
In Starter []
In Generator [0, 1, 2, 3]
In Starter []
In Generator [0, 1, 2, 3, 4]
In Starter []
In Generator [0, 1, 2, 3, 4, 5]
In Starter []
In Generator [0, 1, 2, 3, 4, 5, 6]
In Starter []
In Generator [0, 1, 2, 3, 4, 5, 6, 7]
https://docs.python.org/2/library/multiprocessing.html。第16.6.1.4节 –
您是否愿意演示该示例的解决方案?这是一个最小的,自包含的,可重复的例子,所以它不应该很难。 –