当前位置: 首页 > wzjs >正文

动态网站模板免费下载搭建网站

动态网站模板免费下载,搭建网站,网站建设设计书任务书,自己做的网站怎么爬数据FileInputStream 详解与记忆方法 一、FileInputStream 核心概念 FileInputStream 是 Java 中用于从文件读取原始字节的类,继承自 InputStream 抽象类。 1. 核心特点 特性说明继承关系InputStream → FileInputStream数据单位字节(8bit)用…

FileInputStream 详解与记忆方法

一、FileInputStream 核心概念

FileInputStream 是 Java 中用于从文件读取原始字节的类,继承自 InputStream 抽象类。

1. 核心特点

特性说明
继承关系InputStream → FileInputStream
数据单位字节(8bit)
用途读取二进制文件(如图片、音频、PDF等)
是否缓冲默认无缓冲(需配合 BufferedInputStream 使用)
线程安全

2. 构造方法

java

// 1. 通过文件路径创建
FileInputStream fis = new FileInputStream("test.txt");// 2. 通过File对象创建
File file = new File("test.txt");
FileInputStream fis = new FileInputStream(file);// 3. 通过文件描述符创建(高级用法)
FileDescriptor fd = new FileDescriptor();
FileInputStream fis = new FileInputStream(fd);

3. 核心方法

方法作用
int read()读取单个字节(返回0-255,-1表示结束),调用一次read()方法则读取一个字节,返回读到的字节本身。(例如,信息为a,则返回一个97),如果读不到任何数据则返回-1
int read(byte[] b)读取字节到数组,返回实际读取的字节数(一次最多读取到b.length个字节)
int read(byte[] b, int off, int len)从偏移量off开始读取len个字节到数组
long skip(long n)跳过n个字节
void close()关闭流
FileChannel getChannel()获取关联的FileChannel(NIO相关)
int    available()     返回预估计流当中剩余的字节数量(意思就是:还剩下几个字节没有读取)

二、使用示例

1. 基础读取文件

java

try (FileInputStream fis = new FileInputStream("data.bin")) {int data;while ((data = fis.read()) != -1) {  // 每次读取1字节System.out.print((char) data);   // 转为字符输出(仅适用于文本)}
} // try-with-resources自动关闭流

2. 高效读取(缓冲区)

java

try (FileInputStream fis = new FileInputStream("largefile.bin");BufferedInputStream bis = new BufferedInputStream(fis)) { // 添加缓冲byte[] buffer = new byte[1024];int bytesRead;while ((bytesRead = bis.read(buffer)) != -1) {// 处理buffer中的数据}
}

3. 读取到字节数组

java

File file = new File("data.bin");
byte[] fileData = new byte[(int) file.length()];
try (FileInputStream fis = new FileInputStream(file)) {fis.read(fileData); // 一次性读取全部内容
}

三、记忆技巧

1. 名称解析法

"File + Input + Stream"

  • File:操作文件

  • Input:输入(读取)

  • Stream:字节流

2. 对比记忆法

对比类方向数据单位典型用途
FileInputStream读取字节图片、压缩包等二进制文件
FileOutputStream写入字节文件下载、数据存储
FileReader读取字符文本文件(自动处理编码)

3. 使用场景联想

  • 图片处理FileInputStream + ImageIO.read()

  • 文件复制FileInputStream + FileOutputStream

  • 加密解密:读取原始字节后进行加密运算

4. 常见误区提醒

❌ 错误用法:直接读取文本文件(可能乱码)
✅ 正确做法:文本文件应使用 FileReader 或 InputStreamReader


四、面试高频问题

1. FileInputStream 和 BufferedInputStream 的区别?

  • FileInputStream:每次read()直接访问磁盘,性能低

  • BufferedInputStream:内置缓冲区(默认8KB),减少磁盘IO次数

2. 为什么读取文件要用 try-with-resources?

  • 自动关闭资源:避免忘记调用close()导致文件句柄泄漏

  • 代码简洁:不需要手动写finally

3. 如何高效读取大文件?

java

// 方案1:使用缓冲流
try (BufferedInputStream bis = new BufferedInputStream(new FileInputStream("large.bin"))) {byte[] buffer = new byte[8192];  // 8KB缓冲区while (bis.read(buffer) != -1) {// 处理数据}
}// 方案2:使用NIO的FileChannel(超大文件更高效)

4. read() 方法返回值的含义?

  • 返回int:0-255表示字节值,-1表示文件结束

  • 注意:必须用int接收,byte会无法区分-1和255


五、总结图示

mermaid

flowchart TDA[FileInputStream] --> B[读取二进制文件]A --> C[核心方法: read/skip/close]A --> D[需配合缓冲流提升性能]B --> E[图片/音频/PDF等]D --> F[BufferedInputStream]

一句话总结
"FileInputStream读字节,无缓冲性能低,文本文件别用它,记得关闭保安全"

http://www.dtcms.com/wzjs/409522.html

相关文章:

  • 链接网站怎么做免费推广的平台都有哪些
  • 深圳有哪些做网站公司千锋教育培训怎么样
  • 贵阳官网建设价格合肥关键词优化平台
  • 绵阳网站建设哪家好青岛网站seo优化
  • 政府网站集群建设关键词优化是怎样收费的
  • 上饶有哪些做网站的公司谷歌paypal官网登录入口
  • 做网站一屏的尺寸是镇江网站seo
  • 清溪镇网站仿做seo综合查询网站
  • 动漫谷网站建设策划书网络营销包括
  • 营销型网站建设市场分析关键词优化靠谱推荐
  • 免费建设网站百家号自媒体平台注册
  • 网站开发的费用申请每日关键词搜索排行
  • 宁波营销型网站建设优化建站足球直播在线直播观看免费cctv5
  • 百度seo关键词优化电话seo排名点击器曝光行者seo
  • 旅游网站建设目标平台优化
  • 怎么做带后台的网站app宣传推广方案
  • 眉山网站制作百度识图识别
  • 网页制作怎么做多个网站路由优化大师
  • 网站在政务新媒体建设方案百度的营销推广模式
  • 荔湾区网站设计商品推广软文范例300字
  • 网页源代码怎么看懂长沙企业seo服务
  • 上海网站制作库榆白杨seo博客
  • 做调查网站怎样换IP电商网站对比表格
  • 发稿计划抖音seo是什么
  • 博彩网站开发建设农村电商平台有哪些
  • 莱芜市网站建设设计网络宣传策划方案
  • 怎样用wordpress做网站竞价外包托管费用
  • 怎样制作个人网站淘宝关键词优化怎么弄
  • 怎么做自己的网站卖东西公司的公关
  • 我的世界做弊端网站杭州关键词优化外包