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

本文涉及的产品
实时计算 Flink 版,5000CU*H 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
大数据开发治理平台 DataWorks,不限时长
简介: 【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();
}

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();
}

三、常见问题与易错点

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();
}

五、总结

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

目录
相关文章
|
5天前
|
Java
【Java开发指南 | 第二十一篇】Java流之文件
【Java开发指南 | 第二十一篇】Java流之文件
14 0
|
5天前
|
安全 Java 开发者
Java中的读写锁ReentrantReadWriteLock详解,存在一个小缺陷
Java中的读写锁ReentrantReadWriteLock详解,存在一个小缺陷
13 2
|
4天前
|
消息中间件 Java Kafka
Java大文件排序(有手就能学会),kafka面试题2024
Java大文件排序(有手就能学会),kafka面试题2024
|
5天前
|
存储 JSON 安全
Python中的文件操作与文件IO操作
【5月更文挑战第14天】在Python中,文件操作是常见任务,包括读取、写入和处理文件内容。`open()`函数是核心,接受文件路径和模式(如'r'、'w'、'a'、'b'和'+')参数。本文详细讨论了文件操作基础,如读写模式,以及文件IO操作,如读取、写入和移动指针。异常处理是关键,使用`try-except`捕获`FileNotFoundError`和`PermissionError`等异常。进阶技巧涉及`with`语句、`readline()`、`os`和`shutil`模块。数据序列化与反序列化方面,介绍了
18 0
|
5天前
|
监控 Java
Java一分钟之-NIO:非阻塞IO操作
【5月更文挑战第14天】Java的NIO(New IO)解决了传统BIO在高并发下的低效问题,通过非阻塞方式提高性能。NIO涉及复杂的选择器和缓冲区管理,易出现线程、内存和中断处理的误区。要避免这些问题,可以使用如Netty的NIO库,谨慎设计并发策略,并建立标准异常处理。示例展示了简单NIO服务器,接收连接并发送欢迎消息。理解NIO工作原理和最佳实践,有助于构建高效网络应用。
8 2
|
5天前
|
安全 Java 开发者
Java一分钟之-文件与目录操作:Path与Files类
【5月更文挑战第13天】Java 7 引入`java.nio.file`包,`Path`和`Files`类提供文件和目录操作。`Path`表示路径,不可变。`Files`包含静态方法,支持创建、删除、读写文件和目录。常见问题包括:忽略异常处理、路径解析错误和权限问题。在使用时,注意异常处理、正确格式化路径和考虑权限,以保证代码稳定和安全。结合具体需求,这些方法将使文件操作更高效。
11 2
|
5天前
|
存储 安全 Java
Java一分钟:缓冲流提升读写效率
【5月更文挑战第11天】Java I/O的缓冲流通过内存缓冲区提升读写性能,实现批量处理和预读写。注意避免缓冲区溢出、忘记刷新和关闭以及数据同步问题。示例展示了字节和字符缓冲流在文件复制中的应用,降低磁盘I/O次数,提高效率。熟练掌握缓冲流使用有助于优化Java程序的I/O性能。
50 2
|
3天前
|
Java 测试技术
Java多线程的一些基本例子
【5月更文挑战第17天】Java多线程允许并发执行任务。示例1展示创建并启动两个`MyThread`对象,各自独立打印"Hello World"。示例2的`CounterExample`中,两个线程(IncrementThread和DecrementThread)同步地增加和减少共享计数器,确保最终计数为零。这些例子展示了Java线程的基本用法,包括线程同步,还有如Executor框架和线程池等更复杂的用例。
10 0
|
4天前
|
缓存 安全 Java
7张图带你轻松理解Java 线程安全,java缓存机制面试
7张图带你轻松理解Java 线程安全,java缓存机制面试
|
1天前
|
Java
Java一分钟之-并发编程:线程间通信(Phaser, CyclicBarrier, Semaphore)
【5月更文挑战第19天】Java并发编程中,Phaser、CyclicBarrier和Semaphore是三种强大的同步工具。Phaser用于阶段性任务协调,支持动态注册;CyclicBarrier允许线程同步执行,适合循环任务;Semaphore控制资源访问线程数,常用于限流和资源池管理。了解其使用场景、常见问题及避免策略,结合代码示例,能有效提升并发程序效率。注意异常处理和资源管理,以防止并发问题。
23 2
http://www.vxiaotou.com