scala Future sequence
所属分类 scala
浏览量 717
scala.concurrent.Future#sequence
Useful for reducing many Futures into a single Future.
收集 Future 执行结果,通过 foreach 取出收集结果并进行后续处理
import java.time.LocalDateTime
import scala.concurrent.ExecutionContext.Implicits.global
import scala.concurrent.Future
object FutureSequenceDemo {
def main(args: Array[String]) {
val f1 = Future {
Thread.sleep(2000)
println("Future1.time=" + LocalDateTime.now().toString())
println("Future1.currentThread=" + Thread.currentThread().getName)
"a"
}
val f2 = Future {
Thread.sleep(1000)
println("Future2.time=" + LocalDateTime.now().toString())
println("Future2.currentThread=" + Thread.currentThread().getName)
"b"
}
// Future[List[String]]
val f3 = Future.sequence(List(f1, f2))
f3.foreach(println)
println("time1=" + LocalDateTime.now())
println("f3=" + f3)
println("time2=" + LocalDateTime.now())
Thread.sleep(3000)
println("f3.2=" + f3)
}
}
time1=2022-02-14T12:32:27.126
f3=Future(< not completed >)
time2=2022-02-14T12:32:27.129
Future1.time=2022-02-14T12:32:28.056
Future1.currentThread=ForkJoinPool-1-worker-13
Future2.time=2022-02-14T12:32:29.055
Future2.currentThread=ForkJoinPool-1-worker-11
List(a, b)
f3.2=Future(Success(List(a, b)))
上一篇
下一篇
scala 学的走火入魔
spark 广播变量
scala future for 实例
scala Promise
Scala并发之 Future ExecutionContext
scala type 关键字