隨筆 - 11  文章 - 33  trackbacks - 0
          <2008年11月>
          2627282930311
          2345678
          9101112131415
          16171819202122
          23242526272829
          30123456

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          文章檔案

          搜索

          •  

          最新隨筆

          最新評論

          閱讀排行榜

          評論排行榜

          今天在做測試的時候發現為了醒目用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 閱讀(1373) 評論(4)  編輯  收藏 所屬分類: Java學習

          FeedBack:
          # re: System.err與System.out的區別 2007-09-17 17:55 匿名
          我也納悶呢  回復  更多評論
            
          # re: System.err與System.out的區別[未登錄] 2007-10-30 21:18 Sunny
          謝謝  回復  更多評論
            
          # re: System.err與System.out的區別 2008-10-13 20:42 key_hua
          謝謝  回復  更多評論
            
          # re: System.err與System.out的區別 2008-11-18 14:40 ZLCIsOnly
          謝了 很好  回復  更多評論
            
          主站蜘蛛池模板: 岗巴县| 游戏| 宝应县| 来凤县| 嘉善县| 中宁县| 漳州市| 宜兰县| 永春县| 遂宁市| 黔江区| 札达县| 平凉市| 平原县| 兖州市| 南阳市| 淮滨县| 平湖市| 新竹县| 五指山市| 盐亭县| 五大连池市| 丁青县| 分宜县| 阿城市| 洛川县| 宁化县| 霍城县| 商城县| 曲阳县| 汝南县| 凤庆县| 延寿县| 佛山市| 志丹县| 麦盖提县| 凤台县| 平舆县| 株洲市| 临高县| 潮州市|