Try this for once,
import scala.concurrent._
import java.util.concurrent.Executors
import scala.util.{ Success, Failure }
object FuturesSequence extends App {
implicit val exec = ExecutionContext.fromExecutor(Executors.newCachedThreadPool)
val f1 = future {
1
}
val f2 = future {
2
}
val lf = List(f1, f2)
val seq = Future.sequence(lf)
seq.onSuccess {
case l => println(l)
}
}
This will always print List(1,2)
. The reason is simple, the exec
above is an ExecutionContext of threads (not daemon threads) where as in your example the ExecutionContext was the default one implicitly taken from ExecutionContext.Implicits.global
which contains daemon threads.
Hence being daemon, the process doesn't wait for seq
future to be completed and terminates. if at all seq
does get completed then it prints. But that doesn't happen always
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…