java io流整理

Java中的流,可以從不同的角度進行分類。

按照數據流的方向不同可以分爲:輸入流和輸出流。

按照處理數據單位不同可以分爲:字節流和字符流。

按照實現功能不同可以分爲:節點流和處理流。

輸出流:


輸入流:


因此輸入和輸出都是從程序的角度來說的。

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

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

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

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


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

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


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.


最後要說的一點是:io流這部分在程序中運行時,我們必須將其分配的內存看做是獨立的,無論是存在硬盤上的文件還是在程序中已經存在的字符串或byte數組和io流都沒有什麼關係。我們可以把byte數組和字符串都看做是io流處理的節點。



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章