sbt 命令抛出空指针异常

Posted

技术标签:

【中文标题】sbt 命令抛出空指针异常【英文标题】:sbt command throws null pointer excepion 【发布时间】:2017-01-19 23:35:04 【问题描述】:

我是 scala 和 sbt 的新手,我想运行 sbt 命令,但我得到一些 Nullpointer 异常,不知道为什么。

我在系统中安装了 scala:

scala -版本 Scala 代码运行器版本 2.11.8 -- 版权所有 2002-2016,LAMP/EPFL

另外,如果我尝试检查 sbt 版本是否正常:

sbt --version sbt 启动器版本 0.13.5

但是当我刚刚运行 sbt 时,我得到了一个异常:

  info] Loading project definition from /home/workspace/myproject
    java.lang.NullPointerException
        at java.util.regex.Matcher.getTextLength(java.base@9-internal/Matcher.java:1747)
        at java.util.regex.Matcher.reset(java.base@9-internal/Matcher.java:402)
        at java.util.regex.Matcher.<init>(java.base@9-internal/Matcher.java:244)
        at java.util.regex.Pattern.matcher(java.base@9-internal/Pattern.java:1108)
        at java.util.regex.Pattern.split(java.base@9-internal/Pattern.java:1221)
        at java.util.regex.Pattern.split(java.base@9-internal/Pattern.java:1288)
        at sbt.IO$.pathSplit(IO.scala:744)
        at sbt.IO$.parseClasspath(IO.scala:859)
        at sbt.compiler.CompilerArguments.extClasspath(CompilerArguments.scala:62)
        at sbt.compiler.MixedAnalyzingCompiler$.withBootclasspath(MixedAnalyzingCompiler.scala:189)
        at sbt.compiler.MixedAnalyzingCompiler$.searchClasspathAndLookup(MixedAnalyzingCompiler.scala:167)
        at sbt.compiler.MixedAnalyzingCompiler$.apply(MixedAnalyzingCompiler.scala:177)
        at sbt.compiler.IC$.incrementalCompile(IncrementalCompiler.scala:138)
        at sbt.Compiler$.compile(Compiler.scala:128)
        at sbt.Compiler$.compile(Compiler.scala:114)
        at sbt.Defaults$.sbt$Defaults$$compileIncrementalTaskImpl(Defaults.scala:814)
        at sbt.Defaults$$anonfun$compileIncrementalTask$1.apply(Defaults.scala:805)
        at sbt.Defaults$$anonfun$compileIncrementalTask$1.apply(Defaults.scala:803)
        at scala.Function1$$anonfun$compose$1.apply(Function1.scala:47)
        at sbt.$tilde$greater$$anonfun$$u2219$1.apply(TypeFunctions.scala:40)
        at sbt.std.Transform$$anon$4.work(System.scala:63)
        at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:226)
        at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:226)
        at sbt.ErrorHandling$.wideConvert(ErrorHandling.scala:17)
        at sbt.Execute.work(Execute.scala:235)
        at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:226)
        at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:226)
        at sbt.ConcurrentRestrictions$$anon$4$$anonfun$1.apply(ConcurrentRestrictions.scala:159)
        at sbt.CompletionService$$anon$2.call(CompletionService.scala:28)
        at java.util.concurrent.FutureTask.run(java.base@9-internal/FutureTask.java:266)
        at java.util.concurrent.Executors$RunnableAdapter.call(java.base@9-internal/Executors.java:514)
        at java.util.concurrent.FutureTask.run(java.base@9-internal/FutureTask.java:266)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(java.base@9-internal/ThreadPoolExecutor.java:1158)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(java.base@9-internal/ThreadPoolExecutor.java:632)
        at java.lang.Thread.run(java.base@9-internal/Thread.java:804)
    [error] (compile:compileIncremental) java.lang.NullPointerException

知道如何解决这个问题吗?

【问题讨论】:

添加你的 sbt 文件来发布 @Vasilisck 抱歉,我不明白你的意思? .sbt 文件是什么?我是第一次使用 sbt 你在哪里运行 sbt 命令?在一个项目里面?如果是这样,那个项目里面有什么? 也许你应该用 Java 8 试试。由于 Java 9 还没有发布,我怀疑 sbt 是否曾经在上面测试过。 @sfrj 你解决了吗?如果是这样,您介意分享您所做的吗? 【参考方案1】:

堆栈跟踪

Loading project definition from /home/workspace/myproject
    java.lang.NullPointerException
        at java.util.regex.Matcher.getTextLength(java.base@9-internal/Matcher.java:1747)
        at java.util.regex.Matcher.reset(java.base@9-internal/Matcher.java:402)
        at java.util.regex.Matcher.<init>(java.base@9-internal/Matcher.java:244)
        at java.util.regex.Pattern.matcher(java.base@9-internal/Pattern.java:1108)
        at java.util.regex.Pattern.split(java.base@9-internal/Pattern.java:1221)
        at java.util.regex.Pattern.split(java.base@9-internal/Pattern.java:1288)

表示您尝试在 JDK 9 下运行 sbt 0.13.5,当时不支持。正如 thirstycrow 在评论中所建议的那样,推荐的做法是使用 JDK 8。

如果您使用的是 JDK 9 或 10,sbt 1.1.6 或更高版本应该使用最新的启动脚本更好地工作。

【讨论】:

以上是关于sbt 命令抛出空指针异常的主要内容,如果未能解决你的问题,请参考以下文章

为啥非空列表会抛出空指针异常?

Android Canvas drawcolor 抛出空指针异常

HashCode 抛出空指针异常

Play 2.4 Finder 抛出空指针异常

SAX XML 解析器抛出空指针异常

JOOQ“IN”查询抛出空指针异常