淺談 JAVA中的IO流

流的分類 java

java.io包中的類對應兩類流,一類流直接從指定的位置(如磁盤文件或內存區域)讀或寫,這類流稱爲結點流(node stream),其它的流則稱爲過濾器(filters)。過濾器輸入流每每是以其它輸入流做爲它的輸入源,通過過濾或處理後再以新的輸入流的形式提供給用戶,過濾器輸出流的原理也相似。
node

Java的經常使用輸入、輸出流

java.io包中的stream類根據它們操做對象的類型是字符仍是字節可分爲兩大類: 字符流和字節流。
數組

  • Java的字節流
InputStream是全部字節輸入流的祖先,而OutputStream是全部字節輸出流的祖先。
  • Java的字符流
Reader是全部讀取字符串輸入流的祖先,而writer是全部輸出字符串的祖先。
結合開始所說的輸入/輸出流 ,出現了個一小框架。

                     字節流                         字符流
輸入流        InputStream               Reader
輸出流        OutputStream            Writer
網絡

JAVA字節流 框架

  • FileInputStream和FileOutputStream
    這兩個類屬於結點流,第一個類的源端和第二個類的目的端都是磁盤文件,它們的構造方法容許經過文件的路徑名來構造相應的流。如:
    FileInputStream infile = new FileInputStream("myfile.dat");
    FileOutputStream outfile = new FileOutputStream("results.dat");
   要注意的是,構造FileInputStream, 對應的文件必須存在而且是可讀的,而構造FileOutputStream時,如輸出文件已存在,則必須是可覆蓋的。

  • BufferedInputStream和BufferedOutputStream
    它們是過濾器流,其做用是提升輸入輸出的效率。
  • DataInputStream和DataOutputStream
    這兩個類建立的對象分別被稱爲數據輸入流和數據輸出流。這是頗有用的兩個流,它們容許程序按與機器無關的風格讀寫Java數據。因此比較適合於網絡上的數據傳輸。這兩個流也是過濾器流,常以其它流如InputStream或OutputStream做爲它們的輸入或輸出。
Java的字符流

    字符流主要是用來處理字符的。Java採用16位的Unicode來表示字符串和字符,對應的字符流按輸入和輸出分別稱爲readers和writers。
  • InputStreamReader和OutputStreamWriter
    在構造這兩個類對應的流時,它們會自動進行轉換,將平臺缺省的編碼集編碼的字節轉換爲Unicode字符。對英語環境,其缺省的編碼集通常爲ISO8859-1。
  • BufferedReader和BufferedWriter
    這兩個類對應的流使用了緩衝,能大大提升輸入輸出的效率。這兩個也是過濾器流,經常使用來對InputStreamReader和OutputStreamWriter進行處理。
對BufferedReader類,該類的 readLine()方法能一次從流中讀入一行,但對於BufferedWriter類,就沒有一次寫一行的方法,因此若要向流中一次寫一行,可用 PrintWriter類將原來的流改形成新的打印流,PrintWriter類有一個方法println(),能一次輸出一行。

字節流:一次讀入或讀出是8位二進制。 dom

字符流:一次讀入或讀出是16位二進制。 編碼

字節流和字符流的原理是相同的,只不過處理的單位不一樣而已。後綴是Stream是字節流,然後綴是ReaderWriter是字符流。 spa

節點流:直接與數據源相連,讀入或讀出。 線程

直接使用節點流,讀寫不方便,爲了更快的讀寫文件,纔有了處理流。 code

處理流:與節點流一塊使用,在節點流的基礎上,再套接一層,套接在節點流上的就是處理流。

Jdk提供的流繼承了四大類:InputStream(字節輸入流)OutputStream(字節輸出流),Reader(字符輸入流),Writer(字符輸出流)。

如下是javaio中經常使用的流。

 

字節輸入流:

字節輸出流:

字符輸入流:

字符輸出流:

簡單介紹其上圖:

對文件進行操做:FileInputStream(字節輸入流),FileOutputStream(字節輸出流),FileReader(字符輸入流),FileWriter(字符輸出流)

對管道進行操做:PipedInputStream(字節輸入流),PipedOutStream(字節輸出流),PipedReader(字符輸入流),PipedWriter(字符輸出流)

PipedInputStream的一個實例要和PipedOutputStream的一個實例共同使用,共同完成管道的讀取寫入操做。主要用於線程操做。

字節/字符數組:ByteArrayInputStreamByteArrayOutputStreamCharArrayReaderCharArrayWriter是在內存中開闢了一個字節或字符數組。

Buffered緩衝流::BufferedInputStreamBufferedOutputStreamBufferedReader,BufferedWriter,是帶緩衝區的處理流,緩衝區的做用的主要目的是:避免每次和硬盤打交道,提升數據訪問的效率。

轉化流:InputStreamReader/OutputStreamWriter,把字節轉化成字符。

數據流:DataInputStreamDataOutputStream

由於平時如果咱們輸出一個8個字節的long類型或4個字節的float類型,那怎麼辦呢?能夠一個字節一個字節輸出,也能夠把轉換成字符串輸出,可是這樣轉換費時間,如果直接輸出該多好啊,所以這個數據流就解決了咱們輸出數據類型的困難。數據流能夠直接輸出float類型或long類型,提升了數據讀寫的效率。

打印流:printStreamprintWriter,通常是打印到控制檯,能夠進行控制打印的地方。

對象流:ObjectInputStreamObjectOutputStream,把封裝的對象直接輸出,而不是一個個在轉換成字符串再輸出。

序列化流:SequenceInputStream

對象序列化:把對象直接轉換成二進制,寫入介質中。

使用對象流須要實現Serializable接口,不然會報錯。而若用transient關鍵字修飾成員變量,不寫入該成員變量,如果引用類型的成員變量爲null,值類型的成員變量爲0.


還有好多類:

像RandomAccessFile類,序列化接口,都十分重要。

Java有一種特殊類型的IO數據流——DataOutputStream——它能夠保證「不管數據來自何種機器,只要使用一個DataInputStream收取這些數據,就可用本機正確的格式保存它們.

之後在把示例加上,還有寫比較好的方法。

其實感受這已是固定模式了,一提到從鍵盤讀取數據 就會聯想到:

new BufferedReader(new InputStreamReader(System.in))

如今水平達不到,仍是記些固定格式比較好,以致於會用。

某個老師也說過,創新是創建在紮實的基礎之上,愈來愈以爲基礎重要了。

相關文章
相關標籤/搜索