首页 >Java >java教程 >为什么 System.out.println() 和 System.err.println() 不按预期顺序输出?

为什么 System.out.println() 和 System.err.println() 不按预期顺序输出?

Linda Hamilton
Linda Hamilton原创
2024-12-15 07:25:11223浏览

Why Doesn't System.out.println() and System.err.println() Output in the Expected Order?

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn