我在使用 Spark 和 Scala 时遇到了一个奇怪的错误。我有一段代码声明了一个变量:
var offset = 0
这会导致以下异常:
java.lang.NoSuchMethodError: scala.runtime.IntRef.create(I)Lscala/runtime/IntRef;
at my.package.MyClass$class.myMethod(MyClass.scala:5)
...
它直接指向变量声明。我正在使用 Scala 2.11.2。编译工作。这是一个运行时错误。运行
sbt package
时,我没有收到任何依赖项/版本不匹配警告任何一个。
最佳答案
这几乎可以肯定是 Scala 版本不匹配。
对比v2.10和v2.11中IntRef的定义,可以看到create
仅在后一个版本中引入(参见 https://github.com/scala/scala/blob/v2.10.4/src/library/scala/runtime/IntRef.java 和 https://github.com/scala/scala/blob/v2.11.0/src/library/scala/runtime/IntRef.java )。
您可以打赌,您的某些依赖项是针对 <2.11.0 的 Scala 版本编译的。
您可能想尝试 sbt-dependency-graph ( https://github.com/jrudolph/sbt-dependency-graph ) 来检查您的传递依赖项。
关于scala - 声明变量时出现 NoSuchMethodError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27925375/