成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JAVA IO源碼學(xué)習(xí)系列一(ByteArrayInputStream)

Keven / 1470人閱讀

摘要:簡(jiǎn)介字節(jié)數(shù)組輸入流上一篇簡(jiǎn)單的介紹了一下字節(jié)輸入流的超類,只提及了一下超類中定義的一些方法字節(jié)數(shù)組輸入流是超類的一個(gè)具體的實(shí)現(xiàn)主要的操作實(shí)際上就是讀取操作一個(gè)字節(jié)數(shù)組,類中定義了一個(gè)緩沖的字節(jié)數(shù)組,具體的操作通過定義一下標(biāo)志位,操作次數(shù)等進(jìn)

簡(jiǎn)介 ByteArrayInputStream 字節(jié)數(shù)組輸入流

上一篇簡(jiǎn)單的介紹了一下字節(jié)輸入流的超類,只提及了一下超類中定義的一些方法;字節(jié)數(shù)組輸入流是超類的一個(gè)具體的實(shí)現(xiàn):主要的操作實(shí)際上就是讀取操作一個(gè)字節(jié)數(shù)組,類中定義了一個(gè)緩沖的字節(jié)數(shù)組,具體的操作通過定義一下標(biāo)志位,操作次數(shù)等進(jìn)行讀取該字節(jié)數(shù)組中的內(nèi)容;

1.主要方法源碼介紹

1.介紹過程依據(jù)第一篇中的描述的過程;
(1)首先介紹類中的屬性內(nèi)容:

//存放字節(jié)流數(shù)組,實(shí)際的操作的數(shù)據(jù)內(nèi)容
protected byte buf[];
//當(dāng)前讀取的位置,在相關(guān)操作中會(huì)修改這個(gè)讀取位置
protected int pos;
//標(biāo)記讀取的位置,如果有需要標(biāo)記,可以使用mark()方法標(biāo)記位置
protected int mark = 0;
//字節(jié)流數(shù)組大小
protected int count;

(2)然后是定義構(gòu)造字節(jié)數(shù)組內(nèi)容:該類提供了兩種方式的構(gòu)造函數(shù);第一種直接指定字節(jié)數(shù)組輸入流中緩沖的流數(shù)組,(這樣后續(xù)的讀取等操作都是在處理這個(gè)數(shù)組中的數(shù)據(jù)),該構(gòu)造函數(shù)中設(shè)置了上面提到的相關(guān)屬性;
第二種則指定了具體位置和大小,但實(shí)際的數(shù)據(jù)已全部在緩沖的數(shù)組中,只是確實(shí)了讀取的位置和大小,所以可以讀取的內(nèi)容比實(shí)際的內(nèi)容少;

public ByteArrayInputStream(byte buf[]) {
        this.buf = buf;
        this.pos = 0;
        this.count = buf.length;
    }
    
    public ByteArrayInputStream(byte buf[], int offset, int length) {
        this.buf = buf;
        this.pos = offset;
        this.count = Math.min(offset + length, buf.length);
        this.mark = offset;
    }

(3)判斷是否還能讀?。焊鶕?jù)當(dāng)前讀取的位置來(lái)確定是否還有數(shù)據(jù)

 public synchronized int available() {
        return count - pos;
    }

(4)具體的讀取數(shù)據(jù):讀取操作及先判斷滿足讀取條件后讀取一個(gè)緩沖數(shù)組中的數(shù)據(jù),并將讀取位置+1,&0xff的意義在于保證數(shù)據(jù)操作的一致性(計(jì)算機(jī)存儲(chǔ)數(shù)據(jù)機(jī)制方面)

 public synchronized int read() {
        return (pos < count) ? (buf[pos++] & 0xff) : -1;
    }
   

讀取數(shù)據(jù)到指定的字節(jié)數(shù)組中,可以指定讀取的位置和大小

public synchronized int read(byte b[], int off, int len) {
        if (b == null) {
            throw new NullPointerException();
        } else if (off < 0 || len < 0 || len > b.length - off) {
            throw new IndexOutOfBoundsException();
        }

        if (pos >= count) {
            return -1;
        }

        int avail = count - pos;
        if (len > avail) {
            len = avail;
        }
        if (len <= 0) {
            return 0;
        }
        System.arraycopy(buf, pos, b, off, len);
        pos += len;
        return len;
    }

(5)操作完記得關(guān)閉close();

2.其他方法簡(jiǎn)介:

1.skip()跳過,忽略:及修改讀取位置

 public synchronized long skip(long n) {
        long k = count - pos;
        if (n < k) {
            k = n < 0 ? 0 : n;
        }

        pos += k;
        return k;
    }

2.mark():標(biāo)記位置,操作過程中標(biāo)記需要的位置,這樣在后面可以通過reset()方法將讀取位置修改到這個(gè)值,這樣就可以再此從此位置讀取數(shù)據(jù);

 public void mark(int readAheadLimit) {
        mark = pos;
    }

3.reset():上面介紹過了,

 public synchronized void reset() {
        pos = mark;
    }
3.差不多就介紹完了,附上自己重寫的代碼
/**
 1. 數(shù)組字節(jié)輸入流
 */
public class MyByteArrayInputStream {
    
    //存放字節(jié)流數(shù)組
    protected byte buffer[];
    
    //當(dāng)前讀取的位置
    protected int position;
    
    //字節(jié)流數(shù)組大小
    protected int counts;
    
    //標(biāo)記讀取的位置
    protected int mark;
    
    /**
     * 指定字節(jié)數(shù)組構(gòu)造輸入流
     * @param buf 指定數(shù)組
     */
    public MyByteArrayInputStream(byte[] buf) {
       this.buffer = buf;
       this.counts = buf.length;
    }
    
    public MyByteArrayInputStream(byte[] buf,int offset,int length) {
        this.position = offset;
        this.mark = offset;
        this.buffer = buf;
        this.counts = Math.min(buf.length, length+offset);
     }
    
    //讀取字節(jié)數(shù)組中的字節(jié)流
    public synchronized int read(){
        return positioncounts){
            return -1;
        }
        //
        int can = counts - position;
        if(length > can){
            length = can;
        }
        
        if(length <=0){
            return 0;
        }
        System.arraycopy(buffer, position, buf, offset, length);
        position += length;
        return length;
    }

    //跳過字節(jié)數(shù)組中的n個(gè)字節(jié)
    public synchronized long skip(long n){
        //當(dāng)前可讀取的數(shù)量
        long can = counts-position;
        //當(dāng)跳過的大小小于可讀取的數(shù)量時(shí)
        if(n < can){
            //值大于0 設(shè)置跳過的次數(shù)為 n ,否則為0;
            can = n < 0 ? 0 : n;
        }
        //設(shè)置當(dāng)前讀取的位置,跳過n個(gè)
        position +=can;
        //返回實(shí)際跳過的值
        return can;
    }
    
    //是否支持標(biāo)記,支持
    public boolean markSupported(){
        return true;
    }
    
    //標(biāo)記當(dāng)前讀取的位置,與重置相對(duì),標(biāo)記之后,使用重置方法可以在指定位置讀取
    public void mark(){
        mark = position;
    }
    //設(shè)置當(dāng)前讀取的位置為上一次標(biāo)記的位置
    public synchronized void reset(){
        position = mark;
    }
    //剩余可以去到的數(shù)量
    public synchronized int available(){
        return  counts-position;
    }
    
    //關(guān)閉操作
    public void close() throws IOException {
    }
}

## 4. 最后召喚神獸##

/**
 *                  ___====-_  _-====___
 *            _--^^^#####//      #####^^^--_
 *         _-^##########// (    ) ##########^-_
 *        -############//  |^^/|  ############-
 *      _/############//   (@::@)   ############\_
 *     /#############((     //     ))#############
 *    -###############    (oo)    //###############-
 *   -#################  / VV   //#################-
 *  -###################/      //###################-
 * _#/|##########/######(   /   )######/##########|#_
 * |/ |#/#/#//  #/##  |  |  /##/#/  /#/#/#| |
 * `  |/  V  V  `   V  #| |  | |/#/  V   "  V  V  |  "
 *    `   `  `      `   / | |  | |    "      "  "   "
 *                     (  | |  | |  )
 *                    __ | |  | | /__
 *                   (vvv(VVV)(VVV)vvv)                
 *                        神獸保佑
 *                       代碼無(wú)BUG!
 */

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/68008.html

相關(guān)文章

  • IOByteArrayInputStream源碼分析

    摘要:主要實(shí)現(xiàn)是通過改變屬性的值來(lái)實(shí)現(xiàn)的這兩個(gè)方法是對(duì)數(shù)據(jù)做標(biāo)記,然后通過方法重置,主要為了方便重復(fù)讀取流的數(shù)據(jù)以上就是的核心實(shí)現(xiàn),其實(shí)可以看到關(guān)鍵的方法都是的,說明流都是阻塞的。 分析開始 ByteArrayInputStream一共有四個(gè)屬性 protected byte buf[];//存放數(shù)據(jù) protected int pos;//讀取數(shù)據(jù)的偏移量 prot...

    hosition 評(píng)論0 收藏0
  • 我的阿里之路+Java面經(jīng)考點(diǎn)

    摘要:我的是忙碌的一年,從年初備戰(zhàn)實(shí)習(xí)春招,年三十都在死磕源碼,三月份經(jīng)歷了阿里五次面試,四月順利收到實(shí)習(xí)。因?yàn)槲倚睦砗芮宄?,我的目?biāo)是阿里。所以在收到阿里之后的那晚,我重新規(guī)劃了接下來(lái)的學(xué)習(xí)計(jì)劃,將我的短期目標(biāo)更新成拿下阿里轉(zhuǎn)正。 我的2017是忙碌的一年,從年初備戰(zhàn)實(shí)習(xí)春招,年三十都在死磕JDK源碼,三月份經(jīng)歷了阿里五次面試,四月順利收到實(shí)習(xí)offer。然后五月懷著忐忑的心情開始了螞蟻金...

    姘擱『 評(píng)論0 收藏0
  • Java IO學(xué)習(xí)筆記四

    摘要:此類中的方法在關(guān)閉此流后仍可被調(diào)用,而不會(huì)產(chǎn)生任何。主要的功能是從緩沖區(qū)讀取字節(jié)構(gòu)造函數(shù)創(chuàng)建一個(gè),使用作為其緩沖區(qū)數(shù)組。緩沖區(qū)會(huì)隨著數(shù)據(jù)的不斷寫入而自動(dòng)增長(zhǎng)。 內(nèi)存操作流 之前的所有的流操作都是針對(duì)文件的,但是有時(shí)候只是想要實(shí)現(xiàn)數(shù)據(jù)間轉(zhuǎn)換,此時(shí)如果我們想要?jiǎng)?chuàng)建一個(gè)文件然后再刪除文件,那樣顯得有點(diǎn)麻煩,因此此時(shí)的內(nèi)存操作流就顯得很適合這類的操作,因?yàn)樗皇窃趦?nèi)存中存儲(chǔ),并不會(huì)真正的創(chuàng)建文...

    oliverhuang 評(píng)論0 收藏0
  • Json-path學(xué)習(xí)筆記<二>

    摘要:該篇主要以代碼示例為主,因?yàn)樯喜蝗?,看不到這個(gè)官方文檔和。因?yàn)榻酉聛?lái)的底層默認(rèn)使用的就是。和功能是一致的。區(qū)別是不會(huì)拋出異常,而會(huì)拋出異常。而解析輸入的文本內(nèi)容依據(jù)默認(rèn)的解析文本的模式。 Json-smart 該篇主要以代碼示例為主,因?yàn)間oogle上不去,看不到Json-smart這個(gè)官方文檔和API。故只例舉一些代碼示例。因?yàn)榻酉聛?lái)的Json-path底層默認(rèn)使用的就是JsonSm...

    Soarkey 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<