今天在做測試的時候發現為了醒目用System.err打出來的信息和普通的System.out打出來的信息的順序出乎我的意料之外,納悶之下google之。發現兩者還是很有區別的。。。
大多數操作系統都有三個標準文件描述符:標準輸入,標準輸出,標準出錯。
三個操作系統的文件描述符映射到編程語言的標準庫中,往往加了一層包裝,但是名字通常還是叫標準輸入,標準輸出,標準出錯。
在其它語言中的一般寫法是:stdin,stdout,stderr(有的語言里大寫,有的語言里小寫)。對應Java中的System.in,System.out,System.err。
在語言層面的實現三個文件描述符都是可以重定向的(只要你想)。但是一般而言,如果你在unix shell或windows command line中使用管道或重定向,則只是針對標準輸入和輸出。
另外,標準輸出和標準出錯的一個區別是,標準輸出往往是帶緩存的,而標準出錯沒有緩存(默認設置,可以改)。所以如果你用標準出錯打印出來的東西可以馬上顯示在屏幕,而標準輸出打印出來的東西可能要再積累幾個字符才能一起打印出來。如果你在應用中混用標準輸出和標準出錯就可能看到這個問題。
總的來說,System.out用于正常的輸出,也就是程序真正想輸出的內容。而System.err用于出錯信息的輸出,也就是你本來不期待看到的東西。
因此,System.err打出來的信息常常會跑到System.out信息的前面去。。。
posted on 2007-09-12 10:40
teasp 閱讀(1364)
評論(4) 編輯 收藏 所屬分類:
Java學習