合并两个Scala Future [列表]

dav*_*vid 5 scala future

我需要将两个Future [List]合并为一个,我想出了以下解决方案:

    def mergeFutureLists[X]( fl1: Future[List[X]], fl2: Future[List[X]] ): Future[List[X]] =
    {
        val lf = List( fl1, fl2 )
        val fll = Future.sequence( lf )
        return fll.map{ x => x.flatMap{ el => el } }
    }
Run Code Online (Sandbox Code Playgroud)

它做我想要的,但它是正确的方式进行?

znu*_*rgl 8

您可以等待结果,然后将它们组合到一个列表中:

def mergeFutureLists[X]( fl1: Future[List[X]], fl2: Future[List[X]] ) = {
  for{
    f1Res <- fl1
    f2Res <- fl2
  } yield (f1Res ::: f2Res)
}
Run Code Online (Sandbox Code Playgroud)


Bru*_*uno 7

您还可以使用Future.reduce

def mergeFutureLists[X]( fl1: Future[List[X]], fl2: Future[List[X]]) = {
  Future.reduce(List(fl1, fl2))(_ ++ _)
}
Run Code Online (Sandbox Code Playgroud)

或者,对于任意数量的将来列表:

def mergeFutureLists[X](fl: Future[List[X]]*): Future[List[X]] = {
  Future.reduce(fl)(_ ++ _)
}
Run Code Online (Sandbox Code Playgroud)