首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >scala未来死锁-固定的4线程池

scala未来死锁-固定的4线程池
EN

Stack Overflow用户
提问于 2015-08-20 00:43:46
回答 1查看 802关注 0票数 0

在周围挖(再一次)

Q1:为什么是死锁?

代码语言:javascript
复制
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个)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-08-20 01:49:10

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

代码语言:javascript
复制
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.
  }
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32107833

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档