我需要将两个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 } } }
它做我想要的,但它是正确的方式进行?
您可以等待结果,然后将它们组合到一个列表中:
def mergeFutureLists[X]( fl1: Future[List[X]], fl2: Future[List[X]] ) = { for{ f1Res <- fl1 f2Res <- fl2 } yield (f1Res ::: f2Res) }
您还可以使用Future.reduce
:
def mergeFutureLists[X]( fl1: Future[List[X]], fl2: Future[List[X]]) = { Future.reduce(List(fl1, fl2))(_ ++ _) }
或者,对于任意数量的将来列表:
def mergeFutureLists[X](fl: Future[List[X]]*): Future[List[X]] = { Future.reduce(fl)(_ ++ _) }