gpt4 book ai didi

ruby - EventMachine 和循环

转载 作者:数据小太阳 更新时间:2023-10-29 07:17:07 24 4
gpt4 key购买 nike

这是我的代码:

EventMachine.run {

conn = EM::Protocols::HttpClient2.connect request.host, 80

req = conn.get(request.query)
req.callback { |response|
p(response.status)
p(response.headers)
p(response.content)
}
}

回调触发,也就是说,我得到状态的字符串输出等。

但我想让它做的是触发回调,然后重复。我计划实现更多逻辑,例如每次调整 URL,但现在,我只希望它:

  1. 检索网址
  2. 触发回调
  3. 重复...

我对这种模式的理解是,该循环中的所有内容都会触发,然后返回,然后一直持续下去,直到我执行 EM.stop

现在,它正在检索 URL 数据,但似乎挂起。

我需要做某种返回才能继续吗?为什么它是挂着的,而不是一遍又一遍地循环?

如果我用一个循环包围上面的整个代码块 do ... end 它按预期工作..这是实现这个的正确方法吗?我想我很困惑,因为我认为 EM.run 中的所有内容在完成时都会重复。

最佳答案

您提供的run block 只运行一次。事件循环不会直接向您公开,而是应该不可见的。不要将 run block 与 while 循环混淆。它只运行一次,但它在 事件循环执行时运行。

如果你想重复一个操作,你需要创建某种堆栈并完成它,每个回调检查堆栈是否还有更多的工作要做,然后发出另一个调用。 EventMachine 应用程序是使用这种回调链方法构建的。

你需要实现类似的东西:

def do_stuff(queue, request = nil)
request ||= queue.pop
return unless (request)

conn = EM::Protocols::HttpClient2.connect request.host, 80

req = conn.get(request.query)
req.callback { |response|
p(response.status)
p(response.headers)
p(response.content)

EventMachine.next_tick do
# This schedules an operation to be performed the next time through
# the event-loop. Usually this is almost immediate.
do_stuff(queue)
end
}
end

在你的事件循环中,你踢了这条链:

EventMachine.run do
queue = [ ... ] # List of things to do
do_stuff(queue)
end

一旦您更好地了解 EventMachine 的工作原理,您可能会找到一种更优雅的方法来实现它。

关于ruby - EventMachine 和循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12030976/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com