我完全是Scala和 JVM 编程的菜鸟。我最近加入的团队使用 scala 构建要在 Spark 上运行的程序。工作中的堆栈稳定且功能强大,但其复杂性与我在家的需求不匹配:仅具有功能性 scala shell以更熟悉该语言,尝试一下,在添加任何语法之前获得正确的语法“环境复杂性”
[注意] 我只是想要一些与本文档相同的东西(所以,请不要根据编译器、sbt、IDE 等来回答)
david@ripper$ java -version
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-8u181-b13-2~deb9u1-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)
david@ripper$ scala -version
Scala code runner version 2.11.8 -- Copyright 2002-2016, LAMP/EPFL
这是我在吃贝壳时得到的
david@ripper$ scala
Exception in thread "main" java.lang.NoClassDefFoundError: javax/script/Compilable
at scala.tools.nsc.interpreter.ILoop.createInterpreter(ILoop.scala:118)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply$mcZ$sp(ILoop.scala:911)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:909)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:909)
at scala.reflect.internal.util.ScalaClassLoader$.savingContextLoader(ScalaClassLoader.scala:97)
at scala.tools.nsc.interpreter.ILoop.process(ILoop.scala:909)
at scala.tools.nsc.MainGenericRunner.runTarget$1(MainGenericRunner.scala:74)
at scala.tools.nsc.MainGenericRunner.run$1(MainGenericRunner.scala:87)
at scala.tools.nsc.MainGenericRunner.process(MainGenericRunner.scala:98)
at scala.tools.nsc.MainGenericRunner$.main(MainGenericRunner.scala:103)
at scala.tools.nsc.MainGenericRunner.main(MainGenericRunner.scala)
这似乎是一个经典问题,尽管我首先与我的系统上安装了Oracle java 11相关。但是,我认为我将 openjdk8 设置为默认的系统范围 JRE:
update-alternatives --config java
Il existe 2 choix pour l'alternative java (qui fournit /usr/bin/java).
Sélection Chemin Priorité État
------------------------------------------------------------
0 /usr/lib/jvm/java-11-oracle/bin/java 1091 mode automatique
1 /usr/lib/jvm/java-11-oracle/bin/java 1091 mode manuel
* 2 /usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java 1081 mode manuel
我错过了什么。不是 scala 使用/usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java
. 我正在使用Debian 9中提供的默认 scala 包