树叶云鸿蒙OS教程:鸿蒙OS BufferedInputStream

BufferedInputStream

java.lang.Object

|—java.io.InputStream

|—|—java.io.FilterInputStream

|—|—|—java.io.BufferedInputStream

public class BufferedInputStream
extends FilterInputStream

BufferedInputStream 向另一个输入流添加了功能,即缓冲输入并支持标记和重置方法的能力。 创建 BufferedInputStream 时,会创建一个内部缓冲区数组。 当流中的字节被读取或跳过时,内部缓冲区会根据需要从包含的输入流中重新填充,一次很多字节。 标记操作会记住输入流中的一个点,并且重置操作会导致在从包含的输入流中获取新字节之前重新读取自最近一次标记操作以来读取的所有字节。

Since:

JDK1.0

字段摘要

修饰符和类型字段描述
protected byte[]buf存储数据的内部缓冲区数组。
protected intcount比缓冲区中最后一个有效字节的索引大一的索引。
protected intmarklimit在随后调用 reset 方法失败之前调用 mark 方法后允许的最大预读。
protected intmarkpos调用最后一个标记方法时 pos 字段的值。
protected intpos缓冲区中的当前位置。
从类 java.io.FilterInputStream 继承的字段
in

构造函数摘要

构造函数描述
BufferedInputStream(InputStream in)创建一个 BufferedInputStream 并保存其参数,即输入流,以供以后使用。
BufferedInputStream(InputStream in, int size)创建具有指定缓冲区大小的 BufferedInputStream,并保存其参数,即输入流,以供以后使用。

方法总结

修饰符和类型方法描述
intavailable()返回可以从此输入流中读取(或跳过)的字节数的估计值,而不会被下一次调用此输入流的方法阻塞。
voidclose()关闭此输入流并释放与该流关联的所有系统资源。
voidmark(int readlimit)参见 InputStream 的 mark 方法的通用约定。
booleanmarkSupported()测试此输入流是否支持 mark 和 reset 方法。
intread()参见 InputStream 的 read 方法的通用约定。
intread(byte[] b, int off, int len)从此字节输入流中将字节读取到指定的字节数组中,从给定的偏移量开始。
voidreset()参见 InputStream 的 reset 方法的通用约定。
longskip(long n)参见 InputStream 的 skip 方法的通用约定。
从类 java.io.FilterInputStream 继承的方法
read
从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

字段详细信息

buf

protected volatile byte[] buf

存储数据的内部缓冲区数组。 必要时,它可以被另一个不同大小的数组替换。

count

protected int count

比缓冲区中最后一个有效字节的索引大一的索引。 该值始终在 0 到 buf.length 的范围内; 元素 buf[0] 到 buf[count-1] 包含从底层输入流获得的缓冲输入数据。

marklimit

protected int marklimit

在随后调用 reset 方法失败之前调用 mark 方法后允许的最大预读。 每当 pos 和 markpos 之间的差值超过 marklimit 时,可以通过将 markpos 设置为 -1 来删除该标记。

markpos

protected int markpos

调用最后一个标记方法时 pos 字段的值。

该值始终在 -1 到 pos 的范围内。 如果输入流中没有标记位置,则该字段为-1。 如果输入流中有标记位置,则 buf[markpos] 是复位操作后作为输入提供的第一个字节。 如果 markpos 不是 -1,则从位置 buf[markpos] 到 buf[pos-1] 的所有字节都必须保留在缓冲区数组中(尽管它们可以移动到缓冲区数组中的另一个位置,并适当调整 计数、位置和标记位置); 除非且直到 pos 和 markpos 之间的差异超过 marklimit,否则它们可能不会被丢弃。

pos

protected int pos

缓冲区中的当前位置。 这是要从 buf 数组中读取的下一个字符的索引。

该值始终在 0 到 count 的范围内。 如果它小于 count,则 buf[pos] 是作为输入提供的下一个字节; 如果它等于 count,那么下一次读取或跳过操作将需要从包含的输入流中读取更多字节。

构造函数详细信息

BufferedInputStream

public BufferedInputStream(InputStream in)

创建一个 BufferedInputStream 并保存其参数,即输入流,以供以后使用。 创建一个内部缓冲区数组并将其存储在 buf 中。

参数:

参数名称参数描述
in底层输入流。

BufferedInputStream

public BufferedInputStream(InputStream in, int size)

创建具有指定缓冲区大小的 BufferedInputStream,并保存其参数,即输入流,以供以后使用。 创建一个长度大小的内部缓冲区数组并将其存储在 buf 中。

参数:

参数名称参数描述
in底层输入流。
size缓冲区大小。

Throws:

Throw名称Throw描述
IllegalArgumentException如果 size <= 0.

方法详情

read

public int read() throws IOException

参见 InputStream 的 read 方法的通用约定。

覆盖:

读入类 FilterInputStream

返回:

数据的下一个字节,如果到达流的末尾,则为 -1。

Throws:

Throw名称Throw描述
IOException如果此输入流已通过调用其 close() 方法关闭,或者发生 I/O 错误。

read

public int read(byte[] b, int off, int len) throws IOException

从此字节输入流中将字节读取到指定的字节数组中,从给定的偏移量开始。

该方法实现了 InputStream 类对应的 [InputStream#read(byte], int, int) 方法的通用约定。 作为额外的便利,它尝试通过重复调用底层流的读取方法来读取尽可能多的字节。 此迭代读取将继续,直到满足以下条件之一:

  • 已读取指定数量的字节,
  • 底层流的read方法返回-1,表示文件结束,或者
  • 底层流的可用方法返回零,表示进一步的输入请求将阻塞。

如果对底层流的第一次读取返回 -1 以指示文件结束,则此方法返回 -1。 否则,此方法返回实际读取的字节数。

鼓励但不要求此类的子类尝试以相同方式读取尽可能多的字节。

覆盖:

读入类 FilterInputStream

参数:

参数名称参数描述
b目标缓冲区。
off开始存储字节的偏移量。
len要读取的最大字节数。

返回:

读取的字节数,如果已到达流的末尾,则为 -1。

Throws:

Throw名称Throw描述
IOException如果此输入流已通过调用其 close() 方法关闭,或者发生 I/O 错误。

skip

public long skip(long n) throws IOException

参见 InputStream 的 skip 方法的通用约定。

覆盖:

跳过类 FilterInputStream

参数:

参数名称参数描述
n要跳过的字节数。

返回:

跳过的实际字节数。

Throws:

Throw名称Throw描述
IOException如果流不支持查找,或者此输入流已通过调用其 close() 方法关闭,或者发生 I/O 错误。

available

public int available() throws IOException

返回可以从此输入流中读取(或跳过)的字节数的估计值,而不会被下一次调用此输入流的方法阻塞。 下一次调用可能是同一个线程或另一个线程。 单次读取或跳过这么多字节不会阻塞,但可能会读取或跳过更少的字节。

此方法返回缓冲区中要读取的剩余字节数 (count – pos) 和调用 in.available() 的结果之和。

覆盖:

在类 FilterInputStream 中可用

返回:

估计可以从该输入流中读取(或跳过)而不阻塞的字节数。

Throws:

Throw名称Throw描述
IOException如果此输入流已通过调用其 close() 方法关闭,或者发生 I/O 错误。

mark

public void mark(int readlimit)

参见 InputStream 的 mark 方法的通用约定。

覆盖:

在类 FilterInputStream 中标记

参数:

参数名称参数描述
readlimit在标记位置无效之前可以读取的最大字节数。

reset

public void reset() throws IOException

参见 InputStream 的 reset 方法的通用约定。

如果 markpos 为 -1(未设置标记或标记已失效),则抛出 IOException。 否则,将 pos 设置为等于 markpos。

覆盖:

在类 FilterInputStream 中重置

Throws:

Throw名称Throw描述
IOException如果此流尚未被标记,或者如果标记已失效,或者流已通过调用其 close() 方法关闭,或者发生 I/O 错误。

markSupported

public boolean markSupported()

测试此输入流是否支持 mark 和 reset 方法。 BufferedInputStream 的 markSupported 方法返回 true。

覆盖:

类 FilterInputStream 中的 markSupported

返回:

一个布尔值,指示此流类型是否支持标记和重置方法。

close

public void close() throws IOException

关闭此输入流并释放与该流关联的所有系统资源。 关闭流后,进一步的 read()、available()、reset() 或 skip() 调用将引发 IOException。 关闭以前关闭的流没有效果。

指定者:

在接口 AutoCloseable 中关闭

指定者:

在接口Closeable中关闭

覆盖:

在类 FilterInputStream 中关闭

Throws:

Throw名称Throw描述
IOException如果发生 I/O 错误。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/156217.html<

(0)
运维的头像运维
上一篇2025-03-15 19:40
下一篇 2025-03-15 19:41

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注