(1)按照數據流的方向不同可以分爲:輸入流和輸出流。
(2)按照處理數據單位不同可以分爲:字節流和字符流。
(3)按照實現功能不同可以分爲:節點流和處理流。
輸出流:從程序輸出到文件
輸入流:從文件輸入到程序
因此輸入和輸出都是從程序的角度來說的。
字節流:一次讀入或讀出是8位二進制。
字符流:一次讀入或讀出是16位二進制。
字節流和字符流的原理是相同的,只不過處理的單位不同而已。後綴是Stream是字節流,而後綴是Reader,Writer是字符流。
節點流:直接與數據源相連,讀入或讀出。
直接使用節點流,讀寫不方便,爲了更快的讀寫文件,纔有了處理流。
處理流:與節點流一塊使用,在節點流的基礎上,再套接一層,套接在節點流上的就是處理流。
Jdk提供的流繼承了四大類:InputStream(字節輸入流),OutputStream(字節輸出流),Reader(字符輸入流),Writer(字符輸出流)。
以下是java中io中常用的流。
字節輸入流:
字節輸出流:
字符輸入流:
字符輸出流:
簡單介紹其上圖:
(1)對文件進行操作:FileInputStream(字節輸入流),FileOutputStream(字節輸出流),FileReader(字符輸入流),FileWriter(字符輸出流)
(2)對管道進行操作:PipedInputStream(字節輸入流),PipedOutStream(字節輸出流),PipedReader(字符輸入流),PipedWriter(字符輸出流)
PipedInputStream的一個實例要和PipedOutputStream的一個實例共同使用,共同完成管道的讀取寫入操作。主要用於線程操作。
(3)字節/字符數組:ByteArrayInputStream,ByteArrayOutputStream,CharArrayReader,CharArrayWriter是在內存中開闢了一個字節或字符數組。
(4)Buffered緩衝流::BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter,是帶緩衝區的處理流,緩衝區的作用的主要目的是:避免每次和硬盤打交道,提高數據訪問的效率。
(5)轉化流:InputStreamReader/OutputStreamWriter,把字節轉化成字符。
(6)數據流:DataInputStream,DataOutputStream。
因爲平時若是我們輸出一個8個字節的long類型或4個字節的float類型,那怎麼辦呢?可以一個字節一個字節輸出,也可以把轉換成字符串輸出,但是這樣轉換費時間,若是直接輸出該多好啊,因此這個數據流就解決了我們輸出數據類型的困難。數據流可以直接輸出float類型或long類型,提高了數據讀寫的效率。
(7)打印流:printStream,printWriter,一般是打印到控制檯,可以進行控制打印的地方。
(8)對象流:ObjectInputStream,ObjectOutputStream,把封裝的對象直接輸出,而不是一個個在轉換成字符串再輸出。
(9)序列化流:SequenceInputStream。
(10)對象序列化:把對象直接轉換成二進制,寫入介質中。
使用對象流需要實現Serializable接口,否則會報錯。而若用transient關鍵字修飾成員變量,不寫入該成員變量,若是引用類型的成員變量爲null,值類型的成員變量爲0.
轉自http://blog.csdn.NET/yuebinghaoyuan/article/details/7388059