在我的项目中,我使用Worker来做一些与事件相关的文件处理,并避免阻止处理其他事件。 我需要的是能够在工作完成时将事件(需要文件处理)置于待机状态(其他组件无需进一步处理),然后恢复处理顺序。
当工作人员完成时,我无法发出新事件,因为这可能导致其他组件重新处理"相同"事件不止一次。
有没有办法延迟(即暂停和恢复)事件传播以实现我的需要?有没有更好的方法来解决我的用例?
附加说明:我无法避免阻止行为,因为我需要使用一些外部(阻塞)库调用。
修改 源代码示例:
splt[-1]
在这种情况下,我想延迟" Handler"事件如此" NextHandler"直到" heavy_task"才会收到它。已经完成了工作。
答案 0 :(得分:1)
根据您更新的问题和编辑;这就是你如何等待"一个事件的完成:
示例:强>
from time import sleep
from circuits import Component, Debugger, handler, Event, Worker, task
class my_event(Event):
pass
def heavy_task():
print "heavy task"
sleep(3)
class NextHandler(Component):
@handler("my_event", priority=10)
def my_event(self, event):
print "Handler 2"
class Handler(Component):
_worker = Worker(process=True)
@handler("my_event", priority=20)
def my_event(self, event):
# Fire and Wait for: task()
# This happens asynchornously under the covers
# but gives you a synchronous API. Effectively
# turning my_event into a coroutine.
yield self.call(task(heavy_task), self._worker)
# This will only print after task() is complete.
print "Handler 1"
class App(Component):
h1 = Handler()
h2 = NextHandler()
def started(self, component):
print "Running"
self.fire(my_event())
if __name__ == '__main__':
(App() + Debugger()).run()
<强>输出:强>
$ python app.py
<registered[worker] (<Worker/worker 5848:MainThread (queued=0) [S]>, <Handler/* 5848:MainThread (queued=0) [S]> )>
<registered[*] (<Handler/* 5848:MainThread (queued=0) [S]>, <App/* 5848:MainThread (queued=4) [R]> )>
<registered[*] (<NextHandler/* 5848:MainThread (queued=0) [S]>, <App/* 5848:MainThread (queued=3) [R]> )>
<registered[*] (<Debugger/* 5848:MainThread (queued=0) [S]>, <App/* 5848:MainThread (queued=2) [R]> )>
<started[*] (<App/* 5848:MainThread (queued=1) [R]> )>
Running
<my_event[*] ( )>
Handler 2
<task[<Worker/worker 5848:MainThread (queued=0) [S]>] (<function heavy_task at 0x7f359df6ade8> )>
heavy task
<task_done[<Worker/worker 5848:MainThread (queued=0) [S]>] (None )>
<task_success[<Worker/worker 5848:MainThread (queued=0) [S]>] (<task[<Worker/worker 5848:MainThread (queued=0) [S]>] (<function heavy_task at 0x7f359df6ade8> )>, None )>
Handler 1
见上面的评论。