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中文網其他相關文章!