Java 8 中 ByteArrayInputStream 类源码分析

本文是《水煮 JDK 源码》系列的第三篇,详细介绍了 ByteArrayInputStream 类,包括成员变量、构造方法、读取字节的方法和其他操作。该类在内存中创建字节数组缓冲区,读取数据后位置自动前进,不支持重复读取。通过示例代码演示了如何使用及如何实现可重复读取。
摘要由CSDN通过智能技术生成

这是《水煮 JDK 源码》系列 的第3篇文章,计划撰写100篇关于JDK源码相关的文章

ByteArrayInputStream 类位于 java.io 包下,继承于 InputStream 类,表示字节数组输入流,它会在内存中创建一个字节数组缓冲区,然后把从输入流中读取的数据全部保存在缓冲区中,其 UML 类图如下:
在这里插入图片描述

1、成员变量

ByteArrayInputStream 中定义了4个成员变量,如下:

/** 存放数据的字节数组缓冲区 */
protected byte buf[];
/** 从字节数组缓冲区读取的下一个字节的位置索引 */
protected int pos;
/** 当前流中标记的位置,初始化时为0 */
protected int mark = 0;
/** 字节数组缓冲区中有效的字节数 */
protected int count;

2、构造方法

创建 ByteArrayInputStream 字节数组输入流主要有以下的两种方式:

public ByteArrayInputStream(byte buf[]) {
   
    this.buf = buf;
    // 第一个要读取的字符位置索引为0
    this.pos = 0;
    this.count = buf.length;
}

public ByteArrayInputStream(byte buf[], int offset, int length) {
   
    this.buf = buf;
    // 第一个读取的位置索引为 offset
    this.pos = offset;
    this.count = Math.min(offset + length, buf.length);
    // 标记位置也为 offset
    this.mark = offset;
}

3、读取字节方法

ByteArrayInputStream 提供了两个读取字节的方法,如下:

public synchronized int read() {
   
    // 如果下一个读取的字符位置大于字节数组的长度,直接返回 -1,说明此时数组已经读完了
    // 每读取一个字节后,pos的位置就自动 +1
    return (pos < count) ? (buf[pos++] & 0xff) : -1;
}

/** 将字节数组输入流中从 off 位置开始之后的最多 len 个长度的字节数据,读取到参数数组 b[] 中,返回的是实际读取的数据长度 */
public synchronized int read(byte b[], int off, 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值