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

FileInputStream

java.lang.Object

|—java.io.InputStream

|—|—java.io.FileInputStream

public class FileInputStream
extends InputStream

FileInputStream 从文件系统中的文件获取输入字节。 可用的文件取决于主机环境。

FileInputStream 用于读取原始字节流,例如图像数据。 要读取字符流,请考虑使用 FileReader。

Since:

JDK1.0

构造函数摘要

构造函数描述
FileInputStream(File file)通过打开与实际文件的连接来创建 FileInputStream,该文件由文件系统中的 File 对象文件命名。
FileInputStream(FileDescriptor fdObj)使用文件描述符 fdObj 创建一个 FileInputStream,它表示与文件系统中实际文件的现有连接。
FileInputStream(String name)通过打开与实际文件的连接来创建 FileInputStream,该文件由文件系统中的路径名 name 命名。

方法总结

修饰符和类型方法描述
intavailable()返回可以从此输入流中读取(或跳过)的剩余字节数的估计值,而不会被下一次调用此输入流的方法阻塞。
voidclose()关闭此文件输入流并释放与该流关联的所有系统资源。
protected voidfinalize()确保在不再引用此文件输入流时调用该文件输入流的 close 方法。
FileChannelgetChannel()返回与此文件输入流关联的唯一 FileChannel 对象。
FileDescriptorgetFD()返回 FileDescriptor 对象,该对象表示与此 FileInputStream 正在使用的文件系统中的实际文件的连接。
intread()从此输入流中读取一个字节的数据。
intread(byte[] b)从此输入流中读取最多 b.length 个字节的数据到字节数组中。
intread(byte[] b, int off, int len)从此输入流中读取最多 len 个字节的数据到一个字节数组中。
longskip(long n)跳过并丢弃输入流中的 n 字节数据。
从类 java.io.InputStream 继承的方法
mark, markSupported, reset
从类 java.lang.Object 继承的方法
clone, equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

构造函数详细信息

FileInputStream

public FileInputStream(String name) throws FileNotFoundException

通过打开与实际文件的连接来创建 FileInputStream,该文件由文件系统中的路径名 name 命名。 创建一个新的 FileDescriptor 对象来表示此文件连接。

首先,如果有一个安全管理器,它的 checkRead 方法会以 name 参数作为它的参数来调用。

如果命名文件不存在,是目录而不是常规文件,或者由于某些其他原因无法打开读取,则抛出 FileNotFoundException。

参数:

参数名称参数描述
name系统相关的文件名。

Throws:

Throw名称Throw描述
FileNotFoundException如果文件不存在,是目录而不是常规文件,或者由于某些其他原因无法打开读取。
SecurityException如果存在安全管理器并且其 checkRead 方法拒绝对文件的读取访问。

FileInputStream

public FileInputStream(File file) throws FileNotFoundException

通过打开与实际文件的连接来创建 FileInputStream,该文件由文件系统中的 File 对象文件命名。 创建一个新的 FileDescriptor 对象来表示此文件连接。

首先,如果存在安全管理器,则调用其 checkRead 方法,并将文件参数表示的路径作为其参数。

如果命名文件不存在,是目录而不是常规文件,或者由于某些其他原因无法打开读取,则抛出 FileNotFoundException。

参数:

参数名称参数描述
file要打开以供阅读的文件。

Throws:

Throw名称Throw描述
FileNotFoundException如果文件不存在,是目录而不是常规文件,或者由于某些其他原因无法打开读取。
SecurityException如果存在安全管理器并且其 checkRead 方法拒绝对文件的读取访问。

FileInputStream

public FileInputStream(FileDescriptor fdObj)

使用文件描述符 fdObj 创建一个 FileInputStream,它表示与文件系统中实际文件的现有连接。

如果有安全管理器,则调用它的 checkRead 方法,并以文件描述符 fdObj 作为其参数,以查看是否可以读取文件描述符。 如果拒绝对文件描述符的读取访问,则会引发 SecurityException。

如果 fdObj 为 null,则抛出 NullPointerException。

如果 fdObj 无效,此构造函数不会引发异常。 但是,如果在结果流上调用方法以尝试对流进行 I/O,则会引发 IOException。

参数:

参数名称参数描述
fdObj要打开以供读取的文件描述符。

Throws:

Throw名称Throw描述
SecurityException如果安全管理器存在并且其 checkRead 方法拒绝对文件描述符的读取访问。

方法详情

read

public int read() throws IOException

从此输入流中读取一个字节的数据。 如果还没有输入可用,则此方法会阻塞。

指定者:

读入类 InputStream

返回:

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

Throws:

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

read

public int read(byte[] b) throws IOException

从此输入流中读取最多 b.length 个字节的数据到字节数组中。 此方法会阻塞,直到某些输入可用。

覆盖:

读入类 InputStream

参数:

参数名称参数描述
b读取数据的缓冲区。

返回:

读入缓冲区的总字节数,如果由于已到达文件末尾而没有更多数据,则为 -1。

Throws:

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

read

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

从此输入流中读取最多 len 个字节的数据到一个字节数组中。 如果 len 不为零,则该方法会阻塞,直到某些输入可用; 否则,不读取任何字节并返回 0。

覆盖:

读入类 InputStream

参数:

参数名称参数描述
b读取数据的缓冲区。
off目标数组 b 中的起始偏移量
len读取的最大字节数。

返回:

读入缓冲区的总字节数,如果由于已到达文件末尾而没有更多数据,则为 -1。

Throws:

Throw名称Throw描述
NullPointerException如果 b 为空。
IndexOutOfBoundsException如果 off 为负数,len 为负数,或者 len 大于 b.length – off
IOException如果发生 I/O 错误。

skip

public long skip(long n) throws IOException

跳过并丢弃输入流中的 n 字节数据。

由于各种原因,skip 方法最终可能会跳过一些较小的字节数,可能为 0。如果 n 为负数,该方法将尝试向后跳过。 如果支持文件在其当前位置不支持向后跳过,则会引发 IOException。 返回实际跳过的字节数。 如果它向前跳过,它会返回一个正值。 如果向后跳过,则返回负值。

此方法可能会跳过比后备文件中剩余的字节更多的字节。 这不会产生异常,并且跳过的字节数可能包括超出后备文件 EOF 的一些字节数。 在跳过结尾后尝试从流中读取将导致 -1 指示文件的结尾。

覆盖:

在 InputStream 类中跳过

参数:

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

返回:

跳过的实际字节数。

Throws:

Throw名称Throw模式
IOException如果 n 为负数,如果流不支持查找,或者发生 I/O 错误。

available

public int available() throws IOException

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

在某些情况下,非阻塞读取(或跳过)可能会在其速度较慢时被阻止,例如通过慢速网络读取大文件时。

覆盖:

在类 InputStream 中可用

返回:

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

Throws:

Throw名称Throw模式
IOException如果此文件输入流已通过调用 close 关闭或发生 I/O 错误。

close

public void close() throws IOException

关闭此文件输入流并释放与该流关联的所有系统资源。

如果此流具有关联的通道,则该通道也将关闭。

指定者:

在接口 AutoCloseable 中关闭

指定者:

在接口Closeable中关闭

覆盖:

在类 InputStream 中关闭

Throws:

Throw名称Throw模式
IOException如果发生 I/O 错误。

getFD

public final FileDescriptor getFD() throws IOException

返回 FileDescriptor 对象,该对象表示与此 FileInputStream 正在使用的文件系统中的实际文件的连接。

返回:

与此流关联的文件描述符对象。

Throws:

Throw名称Throw模式
IOException如果发生 I/O 错误。

getChannel

public FileChannel getChannel()

返回与此文件输入流关联的唯一 FileChannel 对象。

返回通道的初始位置将等于到目前为止从文件中读取的字节数。 从此流中读取字节将增加通道的位置。 显式或通过读取更改通道的位置将更改此流的文件位置。

返回:

与此文件输入流关联的文件通道

Since:

1.4

finalize

protected void finalize() throws IOException

确保在不再引用此文件输入流时调用该文件输入流的 close 方法。

覆盖:

在类 Object 中完成

Throws:

Throw名称Throw模式
IOException如果发生 I/O 错误。

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

(0)
运维的头像运维
上一篇2025-04-02 16:31
下一篇 2025-04-02 16:33

相关推荐

  • 个人主题怎么制作?

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

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

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

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

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

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

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

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

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

    2025-11-20
    0

发表回复

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