Heim >Java >javaLernprogramm >Warum sind die Ausgaben von System.out.println und System.err.println manchmal außer Betrieb?

Warum sind die Ausgaben von System.out.println und System.err.println manchmal außer Betrieb?

Susan Sarandon
Susan SarandonOriginal
2024-12-15 05:16:18216Durchsuche

Why Are System.out.println and System.err.println Outputs Sometimes Out of Order?

System.out.println und System.err.println Unregelmäßigkeit in der Druckreihenfolge

Beim Drucken von Nachrichten auf der Konsole mit System.out.println () und System.err.println() innerhalb einer Schleife kann es zu dem Problem kommen, dass die gedruckten Meldungen nicht in der erwarteten Reihenfolge angezeigt werden. Obwohl die Druckmethoden abwechselnd aufgerufen werden, zeigt die Ausgabe eine gruppierte Reihenfolge eines Nachrichtentyps gefolgt vom anderen an, was zu Verwirrung führt.

Dieses Phänomen tritt auf, weil System.out und System.err unterschiedliche Ausgabeströme darstellen. Jeder Stream verwaltet seinen eigenen Puffer, um die gedruckten Zeichen zwischenzuspeichern, bis er einen bestimmten Schwellenwert erreicht oder ein Flush-Vorgang durchgeführt wird. Der Flush-Vorgang sendet den gepufferten Text an das eigentliche Konsolenfenster.

Im bereitgestellten Codeausschnitt:

public static void main(String[] args) {
    for (int i = 0; i < 5; i++) {
        System.out.println("out");
        System.err.println("err");
    }
}

Die Schleife schreibt wiederholt „out“ in System.out und „err“ in System.fehler. Diese Streams leeren ihre Puffer jedoch unabhängig voneinander. Standardmäßig wird der Flush-Vorgang nach einer bestimmten Zeit oder wenn der Puffer seinen Schwellenwert erreicht, ausgelöst.

Da jeder Stream seinen eigenen Puffer hat, sammeln sich die Zeichen separat an. Nachdem die Schleife abgeschlossen ist, wird der System.out-Puffer geleert und alle angesammelten „out“-Meldungen gedruckt. Anschließend wird der System.err-Puffer geleert und alle „err“-Meldungen gedruckt. Dies führt zu einem ungleichmäßigen Ausgabemuster.

Um dieses Problem zu beheben und sicherzustellen, dass die Nachrichten in der Reihenfolge gedruckt werden, in der sie aufgerufen werden, können Sie jeden Puffer explizit leeren, indem Sie Folgendes verwenden:

System.out.flush();
System.err.flush();

By Durch das Leeren der Puffer erzwingen Sie die sofortige Anzeige der gepufferten Zeichen auf der Konsole und stellen so eine konsistente und logische Druckreihenfolge sicher.

Das obige ist der detaillierte Inhalt vonWarum sind die Ausgaben von System.out.println und System.err.println manchmal außer Betrieb?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn