Java一分钟之-Java IO流:文件读写基础

本文涉及的产品
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
实时计算 Flink 版,5000CU*H 3个月
简介: 【5月更文挑战第10天】本文介绍了Java IO流在文件读写中的应用,包括`FileInputStream`和`FileOutputStream`用于字节流操作,`BufferedReader`和`PrintWriter`用于字符流。通过代码示例展示了如何读取和写入文件,强调了常见问题如未关闭流、文件路径、编码、权限和异常处理,并提供了追加写入与读取的示例。理解这些基础知识和注意事项能帮助开发者编写更可靠的程序。

Java的IO流是处理输入输出操作的核心工具,包括读取文件、写入文件、网络通信等。本文将介绍文件读写的常见操作,分析易错点,并提供代码示例,帮助你快速掌握Java IO流的基础知识。
image.png

一、文件读写概述

Java中的FileInputStreamFileOutputStream用于处理文件的读写。读取文件时,数据从文件流向内存;写入文件时,数据从内存流向文件。

文件读取

  • FileInputStream:从文件中读取字节流。
  • BufferedReader:从字符流(如文件)中读取文本,提高了读取效率。

文件写入

  • FileOutputStream:向文件中写入字节流。
  • PrintWriter:向字符流(如文件)中写入文本,方便格式化输出。

二、常见操作

1. 文件读取

try (FileInputStream fis = new FileInputStream("example.txt");
     BufferedReader br = new BufferedReader(new InputStreamReader(fis))) {
   
   
    String line;
    while ((line = br.readLine()) != null) {
   
   
        System.out.println(line);
    }
} catch (IOException e) {
   
   
    e.printStackTrace();
}
AI 代码解读

2. 文件写入

try (FileOutputStream fos = new FileOutputStream("example.txt");
     PrintWriter writer = new PrintWriter(fos)) {
   
   
    writer.println("Hello, World!");
    writer.println("This is a test.");
} catch (IOException e) {
   
   
    e.printStackTrace();
}
AI 代码解读

三、常见问题与易错点

1. 未关闭流

问题:忘记关闭流可能导致资源泄漏,影响程序性能。 避免:使用try-with-resources语句自动关闭流。

2. 文件路径问题

问题:相对路径可能导致找不到文件,绝对路径更稳定。 避免:使用绝对路径,或确保程序运行目录正确。

3. 编码与解码

问题:默认编码可能与文件实际编码不匹配,导致乱码。 避免:明确指定编码,如new InputStreamReader(fis, "UTF-8")

4. 文件权限

问题:没有写入权限时,写入操作会失败。 避免:确保程序有写入文件的权限,或使用Files类的静态方法处理权限。

5. 文件操作异常处理

问题:忽视异常处理可能导致程序崩溃。 避免:捕获并处理IOException,确保程序健壮性。

四、代码示例:追加写入与读取

// 追加写入
try (FileOutputStream fos = new FileOutputStream("example.txt", true);
     PrintWriter writer = new PrintWriter(fos)) {
   
   
    writer.println("Additional content.");
} catch (IOException e) {
   
   
    e.printStackTrace();
}

// 读取追加内容
try (FileInputStream fis = new FileInputStream("example.txt");
     BufferedReader br = new BufferedReader(new InputStreamReader(fis, StandardCharsets.UTF_8))) {
   
   
    String line;
    while ((line = br.readLine()) != null) {
   
   
        System.out.println(line);
    }
} catch (IOException e) {
   
   
    e.printStackTrace();
}
AI 代码解读

五、总结

理解Java IO流的基本概念,熟练掌握文件读写操作,是进行文件处理的基础。注意流的关闭、文件路径、编码问题,以及异常处理,能够帮助你编写更可靠的程序。在实际开发中,还可以考虑使用BufferedInputStreamBufferedOutputStream提高性能,或使用Files类提供的便捷方法。

目录
打赏
0
0
0
0
282
分享
相关文章
|
3月前
|
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
113 9
【Linux】进程IO|系统调用|open|write|文件描述符fd|封装|理解一切皆文件
本文详细介绍了Linux中的进程IO与系统调用,包括 `open`、`write`、`read`和 `close`函数及其用法,解释了文件描述符(fd)的概念,并深入探讨了Linux中的“一切皆文件”思想。这种设计极大地简化了系统编程,使得处理不同类型的IO设备变得更加一致和简单。通过本文的学习,您应该能够更好地理解和应用Linux中的进程IO操作,提高系统编程的效率和能力。
52 34
解锁“分享文件”高效密码:探秘 Java 二叉搜索树算法
在信息爆炸的时代,文件分享至关重要。二叉搜索树(BST)以其高效的查找性能,为文件分享优化提供了新路径。本文聚焦Java环境下BST的应用,介绍其基础结构、实现示例及进阶优化。BST通过有序节点快速定位文件,结合自平衡树、多线程和权限管理,大幅提升文件分享效率与安全性。代码示例展示了文件插入与查找的基本操作,适用于大规模并发场景,确保分享过程流畅高效。掌握BST算法,助力文件分享创新发展。
阿里云服务器ESSD Entry系统盘测评IOPS、IO读写和时延性能参数
阿里云ESSD Entry云盘是新一代企业级云盘,具备高IOPS、低延迟特性,适合开发与测试场景。它提供10~32,768 GiB容量范围,最大IOPS达6,000,吞吐量150 MB/s,时延1~3 ms。支持按量付费和包年包月,性价比高,特别适合个人开发者和中小企业。详情及价格参考阿里云官网。
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
228 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
2月前
|
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
119 34
Git使用教程-将idea本地Java等文件配置到gitte上【保姆级教程】
本内容详细介绍了使用Git进行版本控制的全过程,涵盖从本地仓库创建到远程仓库配置,以及最终推送代码至远程仓库的步骤。
38 0
|
3月前
|
java 中 IO 流
Java中的IO流是用于处理输入输出操作的机制,主要包括字节流和字符流两大类。字节流以8位字节为单位处理数据,如FileInputStream和FileOutputStream;字符流以16位Unicode字符为单位,如FileReader和FileWriter。这些流提供了读写文件、网络传输等基本功能。
70 10
【JavaEE】——文件IO(万字长文)
文件路径,文本文件,二进制文件,File类,文件流,字节流(InputStream,OutputStream)字符流(Reader,Writer)
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
72 3

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等