【问题标题】:Parallel operation hangs in scala并行操作在scala中挂起
【发布时间】:2017-12-07 00:28:12
【问题描述】:

Scala 菜鸟在这里: val pv = (1 to 100).toArray.par

现在我想对这个并行集合应用映射函数pv

pv.map(_ * 2)

但是上述操作挂起。有什么原因吗?

在 Mac OS X (High Sierra) 上使用 Scala 版本 2.12.4

【问题讨论】:

  • 无法复制。
  • 我有相同的配置(Scala .2.12.4,Mac OS X(High Sierra),问题不可重现。也许它挂在另一部分?你能发布一个可重现的例子(完整功能等)?
  • 我使用的是scala解释器,我只有上面两行。

标签: macos scala


【解决方案1】:

似乎这是由静态初始化程序死锁引起的,请参阅:

https://github.com/scala/scala-parallel-collections/issues/34

这个问题在repl中指出,当创建一个并行集合时,repl会为其生成一个wraper,在初始化时,它会导致死锁

它也可以在程序中重现:

https://github.com/scala/bug/issues/8119

object Foreacher {
  val n = 0
  val m = List(1).par.foreach(_ => n)
  def main(args: Array[String]): Unit = println("Hello, all")
}

【讨论】:

猜你喜欢
  • 1970-01-01
  • 2013-08-18
  • 1970-01-01
  • 1970-01-01
  • 2016-06-14
  • 1970-01-01
  • 2013-08-18
  • 2021-12-03
  • 1970-01-01
相关资源
最近更新 更多