scala未来死锁 - 修复了4线程池

时间:2015-08-20 00:43:47

标签: scala deadlock future

Digging around concurrecny(再次)。

Q1:为什么它会死锁?

implicit val ec = ExecutionContext.fromExecutor(Executors.newFixedThreadPool(4))

val futures = List( Future{1} )

val result: Future[List[Int]] = Future.sequence(futures)

Await.ready(result, Duration.Inf)

当我在池中有5个未来/线程(超过4个)时,我预计会有类似的行为。

1 个答案:

答案 0 :(得分:2)

也许这不是僵局。 我认为主线程正在等待线程池退出。 尝试调用执行程序服务的.shutdown()

import java.util.concurrent.Executors
import scala.concurrent.duration.Duration
import scala.concurrent.{ExecutionContext, Await, Future}

object DeadLockSample1 {
  def main(args: Array[String]) {
    val pool =  Executors.newFixedThreadPool(4)
    implicit val ec = ExecutionContext.fromExecutor(pool)
    Future{1}
    pool.shutdown() // without this, it won't exit.
  }
}