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