Python 多处理观察器
我正在做一个需要多处理的GUI。所以我有一个进程是GUI,另一个进程是永远运行的,它是一个调度器。它们通过manager.list()共享var调度程序(保存并管理事件)。 当GUI成为用户的输入时(单击按钮),它会在调度程序上添加一个事件,并为bouth进程更新此var。 在另一个运行调度程序事件的进程上,当一个事件完成时,它也会修改var调度程序。 我的问题是,当它发生时,我需要得到另一个进程的通知,以便重新加载小部件。我试图实现一个,但由于多处理,我不能这样做Python 多处理观察器,python,multiprocessing,observer-pattern,Python,Multiprocessing,Observer Pattern,我正在做一个需要多处理的GUI。所以我有一个进程是GUI,另一个进程是永远运行的,它是一个调度器。它们通过manager.list()共享var调度程序(保存并管理事件)。 当GUI成为用户的输入时(单击按钮),它会在调度程序上添加一个事件,并为bouth进程更新此var。 在另一个运行调度程序事件的进程上,当一个事件完成时,它也会修改var调度程序。 我的问题是,当它发生时,我需要得到另一个进程的通知,以便重新加载小部件。我试图实现一个,但由于多处理,我不能这样做 你知道有什么方法可以做到这一
你知道有什么方法可以做到这一点吗?我通过下一步来实现:-创建两个manager.list一个用于共享调度程序变量,另一个用于共享布尔列表 一旦任务完成,我会在任务中添加一个True。因此,通过使用函数refresh检查此manager.list()以在内部找到True。一旦找到True,它将重置列表并重新加载小部件
'''SUPPORT FUCTIONS TO TREAT THE MANAGER.LIST'''
def getupdate(schrec):
if len(schrec)>0:
return schrec[-1]
def loadupdate(schrec,sch):
schrec[:]=[]
schrec.append(sch)
def clear_fogt(ogtrec):
ogtrec[:]=[]
ogtrec.append(False)
'''WAITS UNTIL FIND True INSIDE ogtrec ( that is a manager.list() )'''
def refresh():
if True in ogtrec:
clear_fogt(ogtrec)
plot_scheduler()
root.after(1000, refresh)
print('refresh')
'''RUNS THE SCHEDULER'''
def sched_run(schrec,ogtrec):
while True:
#get last update of scheduler var
scheduler = getupdate(schrec)
while len(scheduler.og) == 0:
time.sleep(0.5)
#get last update of scheduler var
scheduler = getupdate(schrec)
print('Scheduler list not empty')
#reload widg some bool change value
ogtrec.append(True)
#RUN
scheduler.send_task_rob()
print('Task is executing')
print(simulation_robot_working(scheduler))
time.sleep(simulation_robot_working(scheduler))
scheduler.check_timing()
print('Checked')
#get last update of scheduler var
scheduler = getupdate(schrec)
scheduler.finish_og()
print('OG updated')
#update scheduler value
loadupdate(schrec, scheduler)
#reload widg
ogtrec.append(True)
print('finished')
print(scheduler.og)
仔细阅读,我尝试使用Queue而不是manager.list(),但它们使GUI速度慢得可笑。所以对我来说这不是一个有用的解决方案。