首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Scala中使用ForkJoinPool

在Scala中使用ForkJoinPool
EN

Stack Overflow用户
提问于 2018-04-15 05:33:47
回答 1查看 297关注 0票数 1

代码:

代码语言:javascript
复制
val executor = new ForkJoinPool()
executor.execute(new Runnable{
  def run = println("This task is run asynchronously")
})
Thread.sleep(10000)

此代码打印:此任务异步运行。

但是如果我删除Thread.sleep(10000),程序就不会打印。然后,我了解到这是因为睡眠可以防止ForkJoinPool中的守护进程线程在对Runnable对象调用run方法之前被终止。

所以,很少有问题:

  1. 这是否意味着ForkJoinPool启动的线程都是守护进程线程?有什么原因吗?
  2. 睡眠对这里有什么帮助?
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-15 05:48:45

答案:

  1. 是的,因为您使用的是默认线程工厂,这就是它的配置方式。如果您愿意,可以向它提供一个自定义线程工厂,并且可以将线程配置为非守护进程。
  2. 睡眠有帮助,因为它阻止程序退出足够长的时间,使线程池线程能够找到任务并执行它。
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49838802

复制
相关文章

相似问题

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