java io 结构_java 的IO类库的基本架构
java IO 操作的類在java.io 包中,大概可以分為以下幾組:
基于字節(jié)操作的接口:InputStream 和 OutputStream
基于字符操作的接口:Writer 和 Reader
基于磁盤操作的接口:File 相關
基于網(wǎng)絡操作的接口:Socket 相關
前兩個是數(shù)據(jù)格式區(qū)分,后兩個是傳輸方式區(qū)分。IO 只是人機交互的手段,除了完成交互功能,我們關注的就是如何提高他的運行效率了,而數(shù)據(jù)格式和傳輸方式是影響效率的最關鍵的因素。
基于字節(jié)操作的接口
以下是 InputStream 的類層次關系圖
其實還有很多子類沒有展示出來,每個子類對應處理不同的操作類型。
以下是 OutputStream 的類層次關系圖
兩個要點:
1、操作數(shù)據(jù)的方式可以組合使用
2、必須制定流最終寫到什么地方:要么是磁盤,要么是網(wǎng)絡中。其實寫網(wǎng)絡也是寫磁盤,只是需要讓操作系統(tǒng)再將數(shù)據(jù)傳送到其他地方,而不是本地磁盤。
基于字符操作的接口
不管是磁盤還是網(wǎng)絡傳輸,最小的存儲單元都是字節(jié),而不是字符,所以IO操作的都是字節(jié)而不是字符,但是為什么有操作字符的IO接口呢?
這是因為我們程序操作的數(shù)據(jù)都是字符形式的,為了方便操作當然要提供直接寫字符的IO接口。
Writer 類層次結構
Reader 類層次結構
Reader 和 Writer 接口都只定義了讀取或寫入數(shù)據(jù)字符的方式,也就是怎么讀或寫,但是沒有指明數(shù)據(jù)要寫到哪里,這里就涉及到磁盤或網(wǎng)絡的工作機制。
字節(jié)和字符轉化接口
前面說過,數(shù)據(jù)持久化或網(wǎng)絡傳輸都是以字節(jié)為單位進行,所以必須有字符字節(jié)轉化工具。
字符編碼類結構如圖,解碼有類似的結構;
從InputStream 到 Reader 的過程要指定編碼字符集,否則使用系統(tǒng)默認的字符集,很可能會出現(xiàn)亂碼問題。StreamDecoder 正是完成從字節(jié)到字符的解碼的實現(xiàn)類。
try {
StringBuffer buffer = new StringBuffer();
char[] buf = new char[1024];
FileReader reader = new FileReader("file");
while (reader.read(buf) > 0) {
buffer.append(buf);
}
buffer.toString();
} catch (Exception e) {
}
FileReader 就是按照上面的工作方式讀取文件的,FileReader 繼承了 InputStreamReader ,實際上是讀取文件流,然后通過StreamDecoder 解碼成 char,只不過這里的解碼字符集是默認字符集。
通過 OutputStreamWriter 類完成了從字符到字節(jié)的編碼過程,由 StreamEncoder 完成編碼過程。
總結
以上是生活随笔為你收集整理的java io 结构_java 的IO类库的基本架构的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 北交所限价申报应当符合的条件
- 下一篇: 黄金价格受到供给因素、需求因素、其他因素