在Java 9上,为什么System.getenv()的输出在jshell中不完整?

sko*_*isa 5 read-eval-print-loop java-9 jshell

我正在使用Windows 10并运行Oracle昨天发布的Java 9版本.

如果我打开一个jshell并输入System.out.println(System.getenv()),输出就像预期的那样,如下面屏幕截图的下半部分所示.

但是,如果我只是输入System.getenv(),则输出中间会丢失大量数据.请参阅下面屏幕截图的初始部分.这似乎是jshell的一个特性,因为在System.getenv()输出中的省略号(" ... ")下面的屏幕截图中(在第二个框中用手绘黄色边缘)完全对应于缺失的数据.

缺少环境变量CommonProgramFiles的结束部分,环境变量SPRING_HOME的开头也是如此,并且还有其他几个环境变量,例如Path,根本没有显示.

在此输入图像描述

(屏幕截图中的某些信息因隐私而模糊不清.)

有没有其他人看到同样的事情(或没有),有没有人有关于为什么jshell这样做的建议?

Mat*_*hew 7

JShell会截断一些在REPL中打印的字符串结果.但是它不会影响到控制台的打印.

我们可以看到同样的事情正在发生:

import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.IntStream;
List<Integer> x = IntStream.range(0,3000).mapToObj(Integer::valueOf).collect(Collectors.toList());
x
Run Code Online (Sandbox Code Playgroud)

我们将看到在该输出中出现与省略号相同的截断.

如果我们打印结果:

System.out.println(x);
Run Code Online (Sandbox Code Playgroud)

我们没有看到这一点.


这是用户可配置的.例如,我们可以创建一个自定义格式模式,允许最多40,000个字符(我们可能不会遇到过高的数字,因此不会发生截断).

/set mode mine normal -command
/set truncation mine 40000
/set feedback mine
Run Code Online (Sandbox Code Playgroud)

这创建了一个名为mine的新反馈模式,它继承了内置模式normal (显然有很多选项,所以我们继承了另一种模式,所以我们不必担心设置所有内容).详情/help /set mode请见.

第二个命令将截断设置为40000个字符.可以对其进行配置,以便截断取决于显示的内容类型.详情/help /set truncation请见.

最后,此处的最后一个命令切换到此反馈模式.现在,除非超过40,000个字符,否则控制台中显示的任何内容都不会被截断.

这个链接以及上面的官方文档和帮助命令有助于解决这个问题,以便写出这个答案.


正常模式显示高达截断前1000个字符.单独使用/set truncation可显示各种截断设置或/set truncation normal显示正常模式的设置.

  • 您的配置命令对我来说非常合适.如果输出被截断,我还找到了一个解释省略号定位的链接:https://bugs.openjdk.java.net/browse/JDK-8166637 (2认同)