之前很少去注意這兩個輸出的差異,想說如果用IDE顯示的話,用System.err會是紅字,但他們細節差異,卻完全不大清楚,因此就去找一些相關資訊!
在標準輸出與錯誤輸出這兩種方式,預設都是用螢幕輸出,如果要做更改的話,將輸出寫到檔案,範例如下
標準輸出 會寫入test_out.txt
錯誤輸出 會寫入test_err.txt
而看到網路上,有人指出這兩個輸出的差異,在執行程式用以下指令
java Test > out.txt 2> err.txt
這樣程式跑的時候,System.out.println就輸出到out.txt中,System.err.println就輸出到err.txt中!
在標準輸出與錯誤輸出這兩種方式,預設都是用螢幕輸出,如果要做更改的話,將輸出寫到檔案,範例如下
try{ System.setOut(new java.io.PrintStream(new java.io.FileOutputStream("test_out.txt"))); }catch(java.io.IOException e){ e.printStackTrace(); } try{ System.setErr(new java.io.PrintStream(new java.io.FileOutputStream("test_err.txt"))); }catch(java.io.IOException e){ e.printStackTrace(); } System.out.println("標準輸出"); System.err.println("錯誤輸出");
標準輸出 會寫入test_out.txt
錯誤輸出 會寫入test_err.txt
而看到網路上,有人指出這兩個輸出的差異,在執行程式用以下指令
java Test > out.txt 2> err.txt
這樣程式跑的時候,System.out.println就輸出到out.txt中,System.err.println就輸出到err.txt中!
留言
張貼留言