System.out.println 和 System.err.println 输出的意外顺序
您对 System.out.println() 和System.err.println() 调用不会按照您的顺序打印到控制台,这是一种常见的情况
在 Java 中,System.out 和 System.err 是两个不同的流,用于将输出写入控制台。 System.out 用于标准输出,而 System.err 用于错误消息。默认情况下,这些流的刷新方式不同。
当您调用 System.out.println() 时,输出将添加到标准输出缓冲区。但是,当您调用 System.err.println() 时,输出将添加到标准输出缓冲区和错误输出缓冲区。这是因为 System.err 旨在显示错误消息,即使标准输出被重定向,也应该始终显示错误消息。
这些缓冲区的内容在不同时间刷新。每当遇到换行符时都会刷新标准输出缓冲区,而当发生错误或程序退出时会刷新错误输出缓冲区。
因此,如果您交替调用 System.out.println () 和 System.err.println() 在一个循环内,输出将不会按您期望的顺序出现。相反,所有 System.out.println() 调用将被刷新在一起,然后是所有 System.err.println() 调用。
解决方案
到修复此问题,您可以在每次调用 System.out.println() 和 System.err.println() 后立即强制刷新缓冲区。这可以使用相应流上的flush()方法来完成。
for (int i = 0; i < 5; i++) { System.out.println("out"); System.out.flush(); // Flush the standard output buffer System.err.println("err"); System.err.flush(); // Flush the error output buffer }
通过添加flush()调用,您可以确保每个流的输出立即发送到控制台,因此它将以正确的顺序出现。
以上是为什么 System.out.println() 和 System.err.println() 不按预期顺序输出?的详细内容。更多信息请关注PHP中文网其他相关文章!