Ruby Celluloid:附加到已经在进行的Future

时间:2014-11-08 22:03:17

标签: ruby concurrency actor celluloid

给定一个Celluloid Actor的实例,您可以使用future异步执行Actor方法,并在稍后的某个时间点使用Future的value方法获取Actor方法的结果(必要时阻止。)

假设我在一个系统中有两个独立的组件,它们都想使用相同的Actor方法,也许是一个非常昂贵的数据库查询。如果这两个组件都单独调用actor.future.expensive_query,则查询将执行两次,每个调用者将获得自己单独的Future对象以检索结果。此外,两个查询将连续执行,而不是同时执行。相反,如果我希望第二次调用actor.future.expensive_query来获取对第一个调用者创建的Future对象的引用,该怎么办?赛璐珞有可能做到这一点吗?

1 个答案:

答案 0 :(得分:0)

是的,但也可以使用普通的Ruby,我将向您展示。

例如,使用此自定义访问者:

def expensive_query!(*args)
  @expensive_query ||= future.expensive_query(*args)
  if @expensive_query.is_a? Celluloid::Future
    @expensive_query = @expensive_query.value
  end
  @expensive_query
end

请记住,如果您想再次运行查询,则需要在外部执行此操作...否则您将提取已运行查询的结果(存储在@expensive_query中):

@expensive_query = nil

例如,可能在reset_expensive_query!