How to resolve a list of futures in Scala

后端 未结 3 1514
遇见更好的自我
遇见更好的自我 2021-02-02 11:05

I have a call that returns a Future. However, I need to make n calls so I will get back n futures. I am wondering how I would get the futures to all resolve before proceeding (w

3条回答
  •  花落未央
    2021-02-02 11:33

    I take it that you want to do something after the Futures are finished ,eg. a callback, without blocking the original call? Then you should do something like this:

    val futures = for (...) yield {
      future {
      ...
      }
    }
    
    val f = Future sequence futures.toList
    
    f onComplete {
      case Success(results) => for (result <- results) doSomething(result)
      case Failure(t) => println("An error has occured: " + t.getMessage)
    }
    

    http://docs.scala-lang.org/overviews/core/futures.html

    So you don't block with an await call, but you still wait for all Futures to complete and then do something on all results. The key aspects is using Future.sequence to join a lot of futures together and then to use a callback to act on the result.

提交回复
热议问题