深入淺析Java中 IO流的繼承結構?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
創(chuàng)新互聯(lián)服務項目包括興慶網(wǎng)站建設、興慶網(wǎng)站制作、興慶網(wǎng)頁制作以及興慶網(wǎng)絡營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯(lián)網(wǎng)行業(yè)的解決方案,興慶網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務的客戶以成都為中心已經(jīng)輻射到興慶省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!Java IO體系結構看似龐大復雜,其實有規(guī)律可循,要弄清楚其結構,需要明白兩點:
1. 其對稱性質:InputStream 與 OutputStream, Reader 與 Writer,他們分別是一套字節(jié)輸入-輸出,字符輸入-輸出體系
2. 原始處理器(適配器)與鏈接流處理器(裝飾器)
其結構圖如下:
Reader-Writer體系
1. 基類
InputStream與OutputStream是所有字節(jié)型輸入輸出流的基抽象類,同時也是適配器(原始流處理器)需要適配的對象,也是裝飾器(鏈接流處理器)裝飾對象的基類.
2. 原始流處理器
原始流處理器接收Byte數(shù)組對象,String對象,FileDescriptor對象將其適配成InputStream,以供其他裝飾器使用,他們都繼承自InputStream 包括如下幾個:
ByteArrayInputStream: 接收Byte數(shù)組為流源,為多線程通信提供緩沖區(qū)操作功能
FileInputStream: 接收一個File作為流源,用于文件的讀取
PipedInputStream: 接收一個PipedOutputStream,與PipedOutputStream配合作為管道使用
StringBufferInputStream: 接收一個String作為流的源(已棄用)
3. 鏈接流處理器
鏈接流處理器可以接收另一個流處理器(InputStream,包括鏈接流處理器和原始流處理器)作為源,并對其功能進行擴展,所以說他們是裝飾器.
1) FilterInputStream繼承自InputStream,是所有裝飾器的父類,FilterInputStream內(nèi)部也包含一個InputStream,這個InputStream就是被裝飾類--一個原始流處理器,它包括如下幾個子類:
BufferedInputStream: 用來將數(shù)據(jù)讀入內(nèi)存緩沖區(qū),并從此緩沖區(qū)提供數(shù)據(jù)
DataInputStream: 提供基于多字節(jié)的讀取方法,可以讀取原始數(shù)據(jù)類型(Byte, Int, Long, Double等等)
LineNumberInputStream: 提供具有行計數(shù)功能的流處理器
PushbackInputStream: 提供已讀取字節(jié)"推回"輸入流的功能
2) ObjectInputStream: 可以將使用ObjectOutputStream寫入的基本數(shù)據(jù)和對象進行反串行化
3) SequenceInputStream: 可以合并多個InputStream原始流,依次讀取這些合并的原始流
對于OutputStream, Reader, Writer的體系結構也跟InputStream的結構類似
看完上述內(nèi)容,你們掌握深入淺析Java中 IO流的繼承結構的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!