inputstream中有幾個 read() 方法和 outputstream中有幾個 write() 方法。它們是一一對應的,而核心的是read()和write()方法。它們都沒實作,所有本質調用是各自實作類實作的該兩個方法。 read() 和 write() ,對應着系統的input和output,即系統的輸出輸入。
也是一個抽象類,即表示所有位元組輸入流實作類的基類。它的作用就是抽象地表示所有要輸出到的目标,例如常見的fileoutstream、filteroutputstream等。它實作了java.io.closeable和java.io.flushable兩個接口。其中空實作了flush方法,即擁有重新整理緩存區位元組數組作用。
那些輸出目标呢?比如:
1) 位元組數組(不代表string類,但可以轉換) 2) 檔案 3) 管道(多線程環境中的資料源) 等等
一樣的,先看源碼:
其中三個核心的write()方法,對應着三個inputstream的read()方法:
1. abstract void write(int b) 抽象方法
對應着,inputstream的read()方法,此方法依舊是抽象方法。因為子類必須實作此方法的一個實作。這就是輸入流的關鍵方法。
二者,下面兩個write方法中調用了此核心方法。
可見,核心的是read()和write()方法在傳統的io是多麼重要。
2. void write(byte b[]) 方法
将指定的byte數組的位元組全部寫入輸出流。該效果實際上是由下一個write方法實作的,隻是調用的額時候指定了長度:
3. void write(byte b[], int off, int len) 方法
将指定的byte數組中從偏移量off開始的len個位元組寫入輸出流。代碼詳細流程解讀如下:
a. 如果 <code>b</code> 為 <code>null</code>,則抛出 <code>nullpointerexception</code>。 b. 如果 <code>off</code> 為負,或 <code>len</code> 為負,或者 <code>off+len</code> 大于數組 <code>b</code> 的長度,則抛出 indexoutofboundsexception。 c. 将數組 <code>b</code> 中的某些位元組按順序寫入輸出流;元素 <code>b[off]</code> 是此操作寫入的第一個位元組,<code>b[off+len-1]</code> 是此操作寫入的最後一個位元組。
重要的事情說三遍:
outputstream 解讀對照着 inputstream來看!注意 一個write對應一個read