【问题标题】:JShell throws StringIndexOutOfBoundsException on startupJShell 在启动时抛出 StringIndexOutOfBoundsException
【发布时间】:2021-06-17 00:50:38
【问题描述】:

我正在尝试在 Debian 10 buster 上启动 jshell。我已经从 Oracle 下载了 jdk-16_linux-x64_bin.tar.gz 并将其解压缩到我的主目录中的“jdk-16”中。我已经设置了 PATH 和 JAVA_HOME:

~$ export PATH=~/jdk-16/bin:$PATH
~$ export JAVA_HOME=~/jdk-16
~$ javac --version
javac 16
~$ java --version
java 16 2021-03-16
Java(TM) SE Runtime Environment (build 16+36-2231)
Java HotSpot(TM) 64-Bit Server VM (build 16+36-2231, mixed mode, sharing)

测试“Hello world”程序可以在这个环境下成功编译运行。但是,当我尝试运行 jshell 时,出现以下错误:

~$ jshell
|  Welcome to JShell -- Version 16
|  For an introduction type: /help intro
Exception in thread "main" java.io.IOError: java.lang.StringIndexOutOfBoundsException: String index out of range: 5
    at jdk.internal.le/jdk.internal.org.jline.utils.Curses.tputs(Curses.java:62)
    at jdk.internal.le/jdk.internal.org.jline.utils.Curses.tputs(Curses.java:45)
    at jdk.internal.le/jdk.internal.org.jline.keymap.KeyMap.key(KeyMap.java:243)
    at jdk.internal.le/jdk.internal.org.jline.reader.impl.LineReaderImpl.key(LineReaderImpl.java:6095)
    at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:197)
    at java.base/java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:179)
    at java.base/java.util.Spliterators$ArraySpliterator.forEachRemaining(Spliterators.java:948)
    at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484)
    at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474)
    at java.base/java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:150)
    at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:173)
    at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
    at java.base/java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:596)
    at jdk.internal.le/jdk.internal.org.jline.reader.impl.LineReaderImpl.bindKeys(LineReaderImpl.java:6103)
    at jdk.internal.le/jdk.internal.org.jline.reader.impl.LineReaderImpl.emacs(LineReaderImpl.java:5813)
    at jdk.internal.le/jdk.internal.org.jline.reader.impl.LineReaderImpl.defaultKeyMaps(LineReaderImpl.java:5789)
    at jdk.internal.le/jdk.internal.org.jline.reader.impl.LineReaderImpl.<init>(LineReaderImpl.java:293)
    at jdk.jshell/jdk.internal.jshell.tool.ConsoleIOContext$2.<init>(ConsoleIOContext.java:133)
    at jdk.jshell/jdk.internal.jshell.tool.ConsoleIOContext.<init>(ConsoleIOContext.java:133)
    at jdk.jshell/jdk.internal.jshell.tool.JShellTool.start(JShellTool.java:978)
    at jdk.jshell/jdk.internal.jshell.tool.JShellToolBuilder.start(JShellToolBuilder.java:254)
    at jdk.jshell/jdk.internal.jshell.tool.JShellToolProvider.main(JShellToolProvider.java:120)
Caused by: java.lang.StringIndexOutOfBoundsException: String index out of range: 5
    at java.base/java.lang.StringLatin1.charAt(StringLatin1.java:48)
    at java.base/java.lang.String.charAt(String.java:711)
    at jdk.internal.le/jdk.internal.org.jline.utils.Curses.doTputs(Curses.java:359)
    at jdk.internal.le/jdk.internal.org.jline.utils.Curses.tputs(Curses.java:60)
    ... 21 more

我也尝试过 jdk-15.0.2,结果相同。 ~/jdk8 中也安装了 Java 8 JDK,但我认为不同版本之间没有任何干扰,因为 PATH 和 JAVA_HOME 设置正确。这个错误的原因是什么?

【问题讨论】:

    标签: java linux debian jshell


    【解决方案1】:

    原因是 curses 库无法正确初始化,因为我有一个“不寻常的”终端设置(我使用的是 rxvt-unicode-256color)。以下设置

    $ export TERM=xterm
    

    已修复错误。

    【讨论】:

      猜你喜欢
      • 2019-08-30
      • 2019-06-20
      • 1970-01-01
      • 1970-01-01
      • 2012-01-15
      • 2016-05-21
      • 2020-10-28
      • 2014-12-31
      • 1970-01-01
      相关资源
      最近更新 更多