Java IO流學習總結,javaio流總結

來源:互聯網
上載者:User

Java IO流學習總結,javaio流總結

Java流操作有關的類或介面:

Java流類圖結構:

流的概念和作用

流是一組有順序的,有起點和終點的位元組集合,是對資料轉送的總稱或抽象。即資料在兩裝置間的傳輸稱為流,流的本質是資料轉送,根據資料轉送特性將流抽象為各種類,方便更直觀的進行資料操作。 

IO流的分類
  • 根據處理資料類型的不同分為:字元流和位元組流

  • 根據資料流向不同分為:輸入資料流和輸出資料流

字元流和位元組流

字元流的由來: 因為資料編碼的不同,而有了對字元進行高效操作的流對象。本質其實就是基於位元組流讀取時,去查了指定的碼錶。 位元組流和字元流的區別:

  • 讀寫單位不同:位元組流以位元組(8bit)為單位,字元流以字元為單位,根據碼錶映射字元,一次可能讀多個位元組。

  • 處理對象不同:位元組流能處理所有類型的資料(片、avi等),而字元流只能處理字元類型的資料。

結論:只要是處理純文字資料,就優先考慮使用字元流。 除此之外都使用位元組流。

輸入資料流和輸出資料流

對輸入資料流只能進行讀操作,對輸出資料流只能進行寫操作,程式中需要根據待傳輸資料的不同特性而使用不同的流。  

Java IO流對象

1.輸入位元組流InputStreamIO 中輸入位元組流的繼承圖可見,可以看出:

  1. InputStream 是所有的輸入位元組流的父類,它是一個抽象類別。

  2. ByteArrayInputStream、StringBufferInputStream、FileInputStream 是三種基本的介質流,它們分別從Byte 數組、StringBuffer、和本地檔案中讀取資料。PipedInputStream 是從與其它線程共用的管道中讀取資料,與Piped 相關的知識後續單獨介紹。

  3. ObjectInputStream 和所有FilterInputStream 的子類都是裝飾流(裝飾器模式的主角)。

2.輸出位元組流OutputStream

IO 中輸出位元組流的繼承圖可見,可以看出:

  1. OutputStream 是所有的輸出位元組流的父類,它是一個抽象類別。

  2. ByteArrayOutputStream、FileOutputStream 是兩種基本的介質流,它們分別向Byte 數組、和本地檔案中寫入資料。PipedOutputStream 是向與其它線程共用的管道中寫入資料,

  3. ObjectOutputStream 和所有FilterOutputStream 的子類都是裝飾流。

3.位元組流的輸入與輸出的對應

圖中藍色的為主要的對應部分,紅色的部分就是不對應部分。紫色的虛線部分代表這些流一般要搭配使用。從上面的圖中可以看出Java IO 中的位元組流是極其對稱的。“存在及合理”我們看看這些位元組流中不太對稱的幾個類吧!

  1. LineNumberInputStream 主要完成從流中讀取資料時,會得到相應的行號,至於什麼時候分行、在哪裡分行是由改類主動確定的,並不是在原始中有這樣一個行號。在輸出部分沒有對應的部分,我們完全可以自己建立一個LineNumberOutputStream,在最初寫入時會有一個基準的行號,以後每次遇到換行時會在下一行添加一個行號,看起來也是可以的。好像更不入流了。

  2. PushbackInputStream 的功能是查看最後一個位元組,不滿意就放入緩衝區。主要用在編譯器的文法、詞法分析部分。輸出部分的BufferedOutputStream 幾乎實現相近的功能。

  3. StringBufferInputStream 已經被Deprecated,本身就不應該出現在InputStream 部分,主要因為String 應該屬於字元流的範圍。已經被廢棄了,當然輸出部分也沒有必要需要它了!還允許它存在只是為了保持版本的向下相容而已。

  4. SequenceInputStream 可以認為是一個工具類,將兩個或者多個輸入資料流當成一個輸入資料流依次讀取。完全可以從IO 包中去除,還完全不影響IO 包的結構,卻讓其更“純潔”――純潔的Decorator 模式。

  5. PrintStream 也可以認為是一個協助工具輔助。主要可以向其他輸出資料流,或者FileInputStream 寫入資料,本身內部實現還是帶緩衝的。本質上是對其它流的綜合運用的一個工具而已。一樣可以踢出IO 包!System.out 和System.out 就是PrintStream 的執行個體!

4.字元輸入資料流Reader

在上面的繼承關係圖中可以看出:

  1. Reader 是所有的輸入字元流的父類,它是一個抽象類別。

  2. CharReader、StringReader 是兩種基本的介質流,它們分別將Char 數組、String中讀取資料。PipedReader 是從與其它線程共用的管道中讀取資料。

  3. BufferedReader 很明顯就是一個裝飾器,它和其子類負責裝飾其它Reader 對象。

  4. FilterReader 是所有自訂具體裝飾流的父類,其子類PushbackReader 對Reader 對象進行裝飾,會增加一個行號。

  5. InputStreamReader 是一個串連位元組流和字元流的橋樑,它將位元組流轉變為字元流。FileReader 可以說是一個達到此功能、常用的工具類,在其原始碼中明顯使用了將FileInputStream 轉變為Reader 的方法。我們可以從這個類中得到一定的技巧。Reader 中各個類的用途和使用方法基本和InputStream 中的類使用一致。後面會有Reader 與InputStream 的對應關係。

5.字元輸出資料流Writer

在上面的關係圖中可以看出:

  1. Writer 是所有的輸出字元流的父類,它是一個抽象類別。

  2. CharArrayWriter、StringWriter 是兩種基本的介質流,它們分別向Char 數組、String 中寫入資料。PipedWriter 是向與其它線程共用的管道中寫入資料,

  3. BufferedWriter 是一個裝飾器為Writer 提供緩衝功能。

  4. PrintWriter 和PrintStream 極其類似,功能和使用也非常相似。

  5. OutputStreamWriter 是OutputStream 到Writer 轉換的橋樑,它的子類FileWriter 其實就是一個實現此功能的具體類(具體可以研究一SourceCode)。功能和使用和OutputStream 極其類似,後面會有它們的對應圖。

6.字元流的輸入與輸出的對應

7.字元流與位元組流轉換

轉換流的特點:

  1. 其是字元流和位元組流之間的橋樑

  2. 可對讀取到的位元組資料經過指定編碼轉換成字元

  3. 可對讀取到的字元資料經過指定編碼轉換成位元組

何時使用轉換流?

  1. 當位元組和字元之間有轉換動作時;

  2. 流操作的資料需要編碼或解碼時。

具體的對象體現:

  1. InputStreamReader:位元組到字元的橋樑

  2. OutputStreamWriter:字元到位元組的橋樑

這兩個流對象是字元體系中的成員,它們有轉換作用,本身又是字元流,所以在構造的時候需要傳入位元組流對象進來。

8.File類

File類是對檔案系統中檔案以及檔案夾進行封裝的對象,可以通過對象的思想來操作檔案和檔案夾。 File類儲存檔案或目錄的各種中繼資料資訊,包括檔案名稱、檔案長度、最後修改時間、是否可讀、擷取當前檔案的路徑名,判斷指定檔案是否存在、獲得目前的目錄中的檔案清單,建立、刪除檔案和目錄等方法。  

9.RandomAccessFile類

該對象並不是流體系中的一員,其封裝了位元組流,同時還封裝了一個緩衝區(字元數組),通過內部的指標來操作字元數組中的資料。 該對象特點:

  1. 該對象只能操作檔案,所以建構函式接收兩種類型的參數:a.字串檔案路徑;b.File對象。

  2. 該對象既可以對檔案進行讀操作,也能進行寫操作,在進行對象執行個體化時可指定操作模式(r,rw)

注意:該對象在執行個體化時,如果要操作的檔案不存在,會自動建立;如果檔案存在,寫資料未指定位置,會從頭開始寫,即覆蓋原有的內容。 可以用於多線程下載或多個線程同時寫資料到檔案。

Java團長

號:javatuanzhang

每日分享Java技術乾貨

長按識別二維碼

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.