[十三]JavaIO之PushBackInputStream
生活随笔
收集整理的這篇文章主要介紹了
[十三]JavaIO之PushBackInputStream
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
功能簡介 PushBackInputStream是針對于輸入的一種擴(kuò)展功能 裝飾器模式中的具體的裝飾類,抽象的裝飾器為FilterInputStream PushBackInputStream的重點(diǎn)在于理解緩沖區(qū)的使用手段
流本身不支持回退功能,想要能夠pushBack 顯然必須能夠緩存數(shù)據(jù)
PushBackInputStream內(nèi)部維護(hù)了一個字節(jié)數(shù)組 不要想當(dāng)然的認(rèn)為,類似BufferedInputStream,內(nèi)部緩沖了一個數(shù)組,所有的數(shù)據(jù)都要經(jīng)過這個緩沖區(qū),然后對他做處理 他內(nèi)部維護(hù)的緩沖區(qū),僅僅保存pushBack的字節(jié) 還需要注意的是他的內(nèi)部緩沖區(qū)是從后往前寫入的,也就是下圖中的,從右往左
下標(biāo)索引大的先寫入
一旦寫滿, 會拋出異常
throw new IOException("Push back buffer is full");?
推回一個字節(jié)
由于是從最后開始,一旦pos等于0也就是到了最前面,就無處可放了
所以拋出異常
否則,就在前面寫入一個
推回 指定字節(jié)數(shù)組b 從off偏移量開始的len個字節(jié)
推回len個長度,既然是從后往前設(shè)置數(shù)據(jù),那么pos的值就是可用 空間 的個數(shù)
如果空間不夠,拋出異常
否則,pos直接向前移動到指定位置
然后借助于System.arraycopy 將b 便宜量off開始拷貝到
是unread(byte[] b, int off, int len)的簡化形式
用于拷貝整個數(shù)組
從unread可以清晰的看出來
內(nèi)部的緩沖區(qū),只是為了給被回退掉的數(shù)據(jù)使用的
每次回退就是在最前面(下表索引較小的位置)? 寫入數(shù)據(jù)
read 只要明確了unread以及內(nèi)部緩沖區(qū)的存放形式即可很清楚的知道read的工作方式了
既然是從最后開始往前依次存放,初始時 pos == buf.length? 那么但凡有數(shù)據(jù),pos必然,小于buf.length
也就是說,讀取一個字節(jié)時,如果回退緩沖內(nèi)有數(shù)據(jù),直接返回一個字節(jié)
否則,調(diào)用父類的read方法,而父類FilterInputStream 只是簡單的 封裝轉(zhuǎn)發(fā)請求
實(shí)際上就是直接使用內(nèi)部的InputStream進(jìn)行處理
多參數(shù)的read方法,將數(shù)據(jù)寫入到指定的字節(jié)數(shù)組b中
回退緩沖區(qū)中有效字節(jié)個數(shù)為avail = buf.length - pos;???
如果緩沖區(qū)中有數(shù)據(jù),那么將首先從回退緩沖區(qū)中讀取數(shù)據(jù)
如果讀取的字節(jié)數(shù)少于 len 個字節(jié),那么它將從底層輸入流中讀取字節(jié)
PushBackInputStream 不支持標(biāo)記點(diǎn)相關(guān)的操作
總結(jié)
PushBackInputStream的實(shí)現(xiàn)邏輯比較清晰 我內(nèi)部有一個緩沖區(qū),你要是回退了我就往里面寫入數(shù)據(jù) 每次的數(shù)據(jù)讀取都是先看看緩沖區(qū)里面有沒有數(shù)據(jù),有的話就先讀取回退緩沖區(qū)的 否則,就再去使用實(shí)際的流去進(jìn)行讀取 看得出來,如果你從來不曾回退過,那么好像什么都一樣,還是使用原來的InputStream 進(jìn)行讀取
流本身不支持回退功能,想要能夠pushBack 顯然必須能夠緩存數(shù)據(jù)
PushBackInputStream內(nèi)部維護(hù)了一個字節(jié)數(shù)組 不要想當(dāng)然的認(rèn)為,類似BufferedInputStream,內(nèi)部緩沖了一個數(shù)組,所有的數(shù)據(jù)都要經(jīng)過這個緩沖區(qū),然后對他做處理 他內(nèi)部維護(hù)的緩沖區(qū),僅僅保存pushBack的字節(jié) 還需要注意的是他的內(nèi)部緩沖區(qū)是從后往前寫入的,也就是下圖中的,從右往左
下標(biāo)索引大的先寫入
一旦寫滿, 會拋出異常
throw new IOException("Push back buffer is full");?
推回一個字節(jié)
由于是從最后開始,一旦pos等于0也就是到了最前面,就無處可放了
所以拋出異常
否則,就在前面寫入一個
推回 指定字節(jié)數(shù)組b 從off偏移量開始的len個字節(jié)
推回len個長度,既然是從后往前設(shè)置數(shù)據(jù),那么pos的值就是可用 空間 的個數(shù)
如果空間不夠,拋出異常
否則,pos直接向前移動到指定位置
然后借助于System.arraycopy 將b 便宜量off開始拷貝到
是unread(byte[] b, int off, int len)的簡化形式
用于拷貝整個數(shù)組
從unread可以清晰的看出來
內(nèi)部的緩沖區(qū),只是為了給被回退掉的數(shù)據(jù)使用的
每次回退就是在最前面(下表索引較小的位置)? 寫入數(shù)據(jù)
read 只要明確了unread以及內(nèi)部緩沖區(qū)的存放形式即可很清楚的知道read的工作方式了
既然是從最后開始往前依次存放,初始時 pos == buf.length? 那么但凡有數(shù)據(jù),pos必然,小于buf.length
也就是說,讀取一個字節(jié)時,如果回退緩沖內(nèi)有數(shù)據(jù),直接返回一個字節(jié)
否則,調(diào)用父類的read方法,而父類FilterInputStream 只是簡單的 封裝轉(zhuǎn)發(fā)請求
實(shí)際上就是直接使用內(nèi)部的InputStream進(jìn)行處理
多參數(shù)的read方法,將數(shù)據(jù)寫入到指定的字節(jié)數(shù)組b中
回退緩沖區(qū)中有效字節(jié)個數(shù)為avail = buf.length - pos;???
如果緩沖區(qū)中有數(shù)據(jù),那么將首先從回退緩沖區(qū)中讀取數(shù)據(jù)
如果讀取的字節(jié)數(shù)少于 len 個字節(jié),那么它將從底層輸入流中讀取字節(jié)
PushBackInputStream 不支持標(biāo)記點(diǎn)相關(guān)的操作
總結(jié)
PushBackInputStream的實(shí)現(xiàn)邏輯比較清晰 我內(nèi)部有一個緩沖區(qū),你要是回退了我就往里面寫入數(shù)據(jù) 每次的數(shù)據(jù)讀取都是先看看緩沖區(qū)里面有沒有數(shù)據(jù),有的話就先讀取回退緩沖區(qū)的 否則,就再去使用實(shí)際的流去進(jìn)行讀取 看得出來,如果你從來不曾回退過,那么好像什么都一樣,還是使用原來的InputStream 進(jìn)行讀取
總結(jié)
以上是生活随笔為你收集整理的[十三]JavaIO之PushBackInputStream的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: React-Native学习指南
- 下一篇: (转)Web Framework 的速度