System.out.println("Start"); String s = ""; //936 * 5 = 4680 characters for (int i = 0; i < 937; i++){ s += "1234 "; } System.out.println(s); System.out.println("End");
在Windows下的java控制台上的“开始”和“结束”之间产生一个空行,但在运行MacOS或Linux时可以正常工作.写入文件而不是使用sysout时也是如此.我试过多台Windows机器.无论我是通过eclipse还是通过cmd执行方法都没关系.
当您将“1234”更改为“1234”或“12g4”或运行次数多于/少于936时,它将按预期在所有操作系统中运行.
任何人都可以确认这个/有关于这个问题的已知错误吗?
解决方法是转到Workspace-> Preferences-> Run / Debug->控制台并将固定宽度控制台设置为4000个字符.这将在4000个字符后包裹你的行,这是一个痛苦,但至少你会得到你的所有输出.
我曾经尝试过Galileo(3.5),Helios(3.6)和Indigo(3.7),并且都表现出了这种行为,但很奇怪,Galileo& OP表示,Helios有一个限制= 818(4090个字符)和Indigo = 936(4680)个字符. 4090让我想到操作系统限制(下一个将是4090 5 crlf,> 4096),它与Eclipse / SWT中引发的错误相匹配.我无法解释为什么接受的字符数有所不同.我只能建议它是操作系统中的东西.
Eclipse中引发了许多重复的错误:
> Bug 19850 – Large string printed in Console overstrikes/disappears depending on length
> Bug 44866 – Truncate long strings in variables view
> Bug 104588 – Unreadable console output under certain conditions
一切似乎都是由于:Bug 11601 – console hangs while displaying long strings without crlf