我需要将两个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)
它做我想要的,但它是正确的方式进行?
您可以等待结果,然后将它们组合到一个列表中:
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)
您还可以使用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)