【发布时间】:2019-10-26 12:11:39
【问题描述】:
假设我有多个要并行运行的任务。
每个任务(方法)都有一个内部递归函数,它基本上从数据库中获取数据并将其保存在一些数据存储中。
[简化的内递归函数]
def simplifiedSomeTask(): Unit = {
@scala.annotation.tailrec
def get(
stream: Stream[SomeEntity],
result: Seq[SomeEntity],
): Stream[SomeEntity] = result match {
case Nil =>
stream
case _ =>
val query = //query to fetch data from database
get(
stream append result.toStream,
query.run.value, // get fetched data from database
)
}
val buffer = collection.mutable.Map.empty[String, String]
get(
Stream.empty,
query.run.value
).foreach { r =>
buffer.put(r.loginId, r.userId)
}
}
当尝试运行 A 时,Future 出于某种原因永远不会结束。
[A]
val f1 =Future { someTask1() }
val f2 =Future { someTask2() }
val f3 =Future { someTask3() }
val f = for {
_ <- f1
_ <- f2
_ <- f3
} yield ()
Await.result(f, Duration.Inf)
但是,B 可以工作(尽管它不是并行运行的)
[B]
val f = for {
_ <- Future { someTask1() }
_ <- Future { someTask2() }
_ <- Future { someTask3() }
} yield ()
Await.result(f, Duration.Inf)
我应该如何修改 A 使其按预期运行?
【问题讨论】: