首頁 > Java > java教程 > 為什麼 Java 中的 System.out.println 和 System.err.println 有時會產生無序輸出?

為什麼 Java 中的 System.out.println 和 System.err.println 有時會產生無序輸出?

Patricia Arquette
發布: 2025-01-01 02:03:10
原創
794 人瀏覽過

Why Does `System.out.println` and `System.err.println` Sometimes Produce Out-of-Order Output in Java?

System.out.println 和System.err.println 的無序輸出

在Java 中,System.out.println ()寫入標準輸出流,而System.err.println() 寫入標準錯誤流。通常,這些流會依序列印到控制台。但是,在某些情況下,此行為可能不一致。

考慮以下程式碼片段:

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

執行此程式時,它會產生以下輸出:

out
out
out
out
out
err
err
err
err
err
登入後複製

輸出不是在「out」和「err”之間交替顯示,而是顯示所有“out”訊息,後面跟著所有“err”訊息。這種差異是由於標準輸出和錯誤流的不同性質造成的。

Java 中的輸出流會被緩存,這表示資料不會立即寫入控制台。相反,它存儲在內部緩衝區中並定期刷新。刷新過程由各種條件觸發,例如一段時間不活動或緩衝區達到特定大小。

在上面的程式碼片段的情況下,標準輸出和錯誤流都寫入各自的緩衝區。由於寫入不同步,因此錯誤流的緩衝區可能會先填滿並被刷新,即使某些「輸出」訊息仍保留在輸出流的緩衝區中。這會導致觀察到的無序輸出。

要解決此問題,您可以確保在每次寫入後刷新兩個輸出流。以下程式碼在迴圈中包含對System.out.flush() 和System.err.flush() 的呼叫:

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

透過此修改,輸出將以預期的交替順序列印:

out
err
out
err
out
err
out
err
out
err
登入後複製

以上是為什麼 Java 中的 System.out.println 和 System.err.println 有時會產生無序輸出?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板