Scala Play framework-2.1.1 AsyncResult:处理多个期货

时间:2013-06-01 03:30:15

标签: scala playframework

我需要根据用户发布的数据生成各种代码片段,因此那些片段生成可以是并行的,我试图使用每个片段和片段生成并组合它们并发送AsyncResult,这里是代码

val p = for {
  pr <- Future { ProviderGenerator.generate(content) }
  c <- Future { ModelGenerator.generate(content) }
} yield(pr, c)

Async {
  if (p.isCompleted)
    println("Futures completed")
  p.onSuccess({
    case (pr: ActionResult, c: ActionResult) => {
      response.add(pr)
      response.add(c)
      Ok(Json.toJson(response))
    }
  })
  p onFailure {
    case _ => println("It failed")
  }
  p.map {
    case (pr: ActionResult, c: ActionResult) => {
      println("I am in case")
      response.add(pr)
      response.add(c)
      Ok(Json.toJson(response))
    }
    case _ => {
      println("I am in else case")
      Ok(Json.toJson(response))
    }
  }
}

这永远不会将结果发送给用户,就好像我在其中使用单一的未来,我得到了回应。我如何处理这样的多种期货?

1 个答案:

答案 0 :(得分:0)

我没有看到明显的问题 - 尝试添加一个p onFailure { case e: Throwable => Logger.error("failed", e) },看看它是否显示未来未完成。