繁体   English   中英

为什么在IntelliJ中,大型Java / Scala项目上的Scala编译失败?

[英]Why does Scala compile fail on large Java/Scala project in IntelliJ?

我有一个带有八个模块和大约500 KLines Java的IntelliJ项目。 我向依赖于所有其他模块的模块添加了Scala Facet。

在IntelliJ IDEA 9.0.2中编译HelloWorld.scala时:

object HelloWorld {
  def main(args: Array[String]) {
    println("Hello World!")
  }
}

我在“消息”面板中得到以下输出:

Information:Compilation completed with 32 errors and 0 warnings
Information:32 errors
Information:0 warnings
Error:Scalac internal error: class java.lang.reflect.InvocationTargetException [sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method), sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39), sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25), java.lang.reflect.Method.invoke(Method.java:597), org.jetbrains.plugins.scala.compiler.rt.ScalacRunner.main(ScalacRunner.java:74)][scala.tools.nsc.typechecker.Typers$class.newTyper(Typers.scala:68), scala.tools.nsc.Global$analyzer$.newTyper(Global.scala:295), scala.tools.nsc.typechecker.Namers$Namer.<init>(Namers.scala:68), scala.tools.nsc.typechecker.Namers$NormalNamer.<init>(Namers.scala:43), scala.tools.nsc.typechecker.Namers$class.newNamer(Namers.scala:44), scala.tools.nsc.Global$analyzer$.newNamer(Global.scala:295), scala.tools.nsc.typechecker.Namers$Namer$$anonfun$enterSyms$1.apply(Namers.scala:258), scala.tools.nsc.typechecker.Namers$Namer$$anonfun$enterSyms$1.apply(Namers.scala:256), scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:61), scala.collection.immutable.List.foreach(List.scala:45), scala.tools.nsc.typechecker.Namers$Namer.enterSyms(Namers.scala:256), scala.tools.nsc.typechecker.Namers$Namer.enterSym(Namers.scala:347), scala.tools.nsc.typechecker.Analyzer$namerFactory$$anon$1.apply(Analyzer.scala:39), scala.tools.nsc.Global$GlobalPhase$$anonfun$applyPhase$1.apply(Global.scala:276), scala.tools.nsc.Global$GlobalPhase$$anonfun$applyPhase$1.apply(Global.scala:276), scala.tools.nsc.reporters.Reporter.withSource(Reporter.scala:48), scala.tools.nsc.Global$GlobalPhase.applyPhase(Global.scala:276), scala.tools.nsc.Global$GlobalPhase$$anonfun$run$1.apply(Global.scala:252), scala.tools.nsc.Global$GlobalPhase$$anonfun$run$1.apply(Global.scala:252), scala.collection.Iterator$class.foreach(Iterator.scala:631), scala.collection.mutable.ListBuffer$$anon$1.foreach(ListBuffer.scala:304), scala.tools.nsc.Global$GlobalPhase.run(Global.scala:252), scala.tools.nsc.Global$Run.compileSources(Global.scala:733), scala.tools.nsc.Global$Run.compile(Global.scala:813), scala.tools.nsc.Main$.process(Main.scala:108), scala.tools.nsc.Main$.main(Main.scala:122), scala.tools.nsc.Main.main(Main.scala), sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method), sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39), sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25), java.lang.reflect.Method.invoke(Method.java:597), org.jetbrains.plugins.scala.compiler.rt.ScalacRunner.main(ScalacRunner.java:74)]
Error:sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
Error:sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
Error:sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
Error:java.lang.reflect.Method.invoke(Method.java:597)
Error:org.jetbrains.plugins.scala.compiler.rt.ScalacRunner.main(ScalacRunner.java:74)
Error:Caused by java.lang.OutOfMemoryError: Java heap space
Error:scala.tools.nsc.typechecker.Typers$class.newTyper(Typers.scala:68)
Error:scala.tools.nsc.Global$analyzer$.newTyper(Global.scala:295)
Error:scala.tools.nsc.typechecker.Namers$Namer.<init>(Namers.scala:68)
Error:scala.tools.nsc.typechecker.Namers$NormalNamer.<init>(Namers.scala:43)
Error:scala.tools.nsc.typechecker.Namers$class.newNamer(Namers.scala:44)
Error:scala.tools.nsc.Global$analyzer$.newNamer(Global.scala:295)
Error:scala.tools.nsc.typechecker.Namers$Namer$$anonfun$enterSyms$1.apply(Namers.scala:258)
Error:scala.tools.nsc.typechecker.Namers$Namer$$anonfun$enterSyms$1.apply(Namers.scala:256)
Error:scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:61)
Error:scala.collection.immutable.List.foreach(List.scala:45)
Error:scala.tools.nsc.typechecker.Namers$Namer.enterSyms(Namers.scala:256)
Error:scala.tools.nsc.typechecker.Namers$Namer.enterSym(Namers.scala:347)
Error:scala.tools.nsc.typechecker.Analyzer$namerFactory$$anon$1.apply(Analyzer.scala:39)
Error:scala.tools.nsc.Global$GlobalPhase$$anonfun$applyPhase$1.apply(Global.scala:276)
Error:scala.tools.nsc.reporters.Reporter.withSource(Reporter.scala:48)
Error:scala.tools.nsc.Global$GlobalPhase.applyPhase(Global.scala:276)
Error:scala.tools.nsc.Global$GlobalPhase$$anonfun$run$1.apply(Global.scala:252)
Error:scala.collection.Iterator$class.foreach(Iterator.scala:631)
Error:scala.collection.mutable.ListBuffer$$anon$1.foreach(ListBuffer.scala:304)
Error:scala.tools.nsc.Global$GlobalPhase.run(Global.scala:252)
Error:scala.tools.nsc.Global$Run.compileSources(Global.scala:733)
Error:scala.tools.nsc.Global$Run.compile(Global.scala:813)
Error:scala.tools.nsc.Main$.process(Main.scala:108)
Error:scala.tools.nsc.Main$.main(Main.scala:122)
Error:scala.tools.nsc.Main.main(Main.scala)

为什么会这样呢? 我可以成功创建一个新的空项目,并编译并运行此Hello World。

问题是您的内存不足:

Error:Caused by java.lang.OutOfMemoryError: Java heap space

那可能是由于您的项目规模。
您需要为编译器调整JVM选项-Xms-Xmx ,以便允许它使用更多的内存。

您是否仔细查看了堆栈跟踪?

Caused by java.lang.OutOfMemoryError: Java heap space

尝试设置最大 JVM的内存量更高(在命令行上,这是-Xmx开关,我不知道如何为IntelliJ设置它-在文档中查找)。

原来这是一个内存问题。 这是带有上下文的编译错误的真正原因:

Error:org.jetbrains.plugins.scala.compiler.rt.ScalacRunner.main(ScalacRunner.java:74)
==> Error:Caused by java.lang.OutOfMemoryError: Java heap space <==
Error:scala.tools.nsc.typechecker.Typers$class.newTyper(Typers.scala:68)

档案| 设置| 编译器 Scala编译器默认将最大堆大小(MB)设置为256

最大堆大小(MB)设置1024可为我解决问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM