活动介绍

Java文件I/O操作全解析

立即解锁
发布时间: 2025-08-21 00:56:29 阅读量: 2 订阅数: 12
PDF

Java编程艺术:从初学者到大师的进阶指南

### Java 文件 I/O 操作全解析 在 Java 编程中,文件 I/O 操作是一项基础且重要的技能。本文将详细介绍 Java 中基于字符流的文件 I/O 操作,以及 `RandomAccessFile` 类的使用,同时会结合实际代码示例进行讲解。 #### 基于字符流的文件 I/O `Reader` 和 `Writer` 类在处理基于字符的文件 I/O 方面比 `InputStream` 和 `OutputStream` 类更强大。这主要是因为它们支持指定字符集编码方案,能够将本地文件编码的字节或字符转换为应用程序所需的编码。 ##### Writers 类 - **FileWriter**:用于创建文件并向其中写入字符。它的功能继承自 `OutputStreamWriter`,但在使用时只能以默认的本地编码写入字符。若需要指定其他编码,需使用 `OutputStreamWriter` 结合 `FileOutputStream`。 ```java import java.io.*; public class FWTesterApp { public static void main(String[] args){ try{ FileWriter fw = new FileWriter("test.txt"); fw.write("This is a test of the FileWriter class.\n"); fw.write("It inherits its functionality from OutputStreamWriter.\n"); fw.write("You can overwrite the contents of a file...\n"); fw.write("...or you can append text to the end of a file."); fw.close(); }catch(Exception ignored){ } } } ``` - **BufferedWriter**:为其他 `Writer` 对象提供输出缓冲功能,通常与 `FileWriter` 或 `OutputStreamWriter` 结合使用,可提高输出效率。它还提供了 `newLine()` 方法,方便写入换行符。 ```java import java.io.*; public class BWTesterApp { public static void main(String[] args){ try{ FileWriter fw = new FileWriter("test.txt"); BufferedWriter bw = new BufferedWriter(fw); bw.write("This is a test of the BufferedWriter class."); bw.newLine(); bw.write("It improves output efficiency by buffering individual disk writes."); bw.newLine(); bw.write("You can specify the internal buffer size at the time of object creation."); bw.newLine(); bw.write("...and it provides a newLine() method!"); bw.flush(); bw.close(); }catch(Exception ignored){ } } } ``` - **OutputStreamWriter**:提供字符编码的灵活性,使用时需先创建一个 `OutputStream` 对象,如 `FileOutputStream`。还可结合 `BufferedWriter` 提高输出效率。 ```java import java.io.*; public class OSWTesterApp { public static void main(String[] args){ try{ FileOutputStream fos = new FileOutputStream("test.txt"); OutputStreamWriter osw = new OutputStreamWriter(fos); BufferedWriter bw = new BufferedWriter(osw); bw.write("Ohhhh do you love Java like I love Java?"); bw.newLine(); bw.write("The OutputStreamWriter needs a FileOutputStream object..."); bw.newLine(); bw.write("...and can be used with a BufferedWriter to improve output efficiency."); bw.newLine(); bw.write("...and it's fun to use!"); bw.flush(); bw.close(); }catch(Exception ignored){ } } } ``` - **PrintWriter**:功能类似于 `PrintStream`,可将 Java 基本类型、对象、字符串和字符的文本表示写入磁盘或其他输出目的地。使用时需结合 `OutputStream` 或 `Writer` 对象,与 `OutputStreamWriter` 结合时可指定所需的字符编码。 ```java import java.io.*; public class PWTesterApp { public static void main(String[] args){ try{ FileOutputStream fos = new FileOutputStream("test.txt"); OutputStreamWriter osw = new OutputStreamWriter(fos); BufferedWriter bw = new BufferedWriter(osw); PrintWriter pw = new PrintWriter(bw); pw.println(123); pw.println(true); pw.println(1.234); pw.println("Ohhhh I love Java!!"); pw.println(new Person("Rick", "W", "Miller", "Male")); pw.flush(); pw.close(); }catch(Exception ignored){ } } } ``` ##### Readers 类 - **FileReader**:从文件中读取字节,并根据默认的本地编码进行转换。若需要对编码方案有更多控制,可直接使用 `InputStreamReader`。 ```java import java.io.*; public class FRTesterApp { public static void main(String[] args){ try{ File file = new File("test.txt"); FileReader fr = new FileReader(file); char[] char_buffer = new char[(int)file.length()]; fr.read(char_buffer); for(int i = 0; i<char_buffer.length; i++){ System.out.print(char_buffer[i]); } fr.close(); }catch(Exception ignored){ } } } ``` - **InputStreamReader**:当需要对将文件中读取的字节转换为字符的编码方案有更多控制时使用,它需要 `InputStream` 对象的支持。 ```java import java.io.*; public class ISRTesterApp { public static void main(String[] args){ try{ File file = new File("test.txt"); FileInputStream fis = new FileInputStream(file); InputStreamReader isr = new InputStreamReader(fis); char[] char_buffer = new char[(int)file.length()]; isr.read(char_buffer); for(int i = 0; i<char_buffer.length; i++){ System.out.print(char_buffer[i]); } isr.close(); }catch(Exception ignored){ } } } ``` - **BufferedReader**:可与 `InputStreamReader` 结合使用,提高输入效率,其内部缓冲区大小可在实例化时指定。 ```java import java.io.*; public class BRTesterApp { public static void main(String[] args){ try{ File file = new File("test.txt"); FileInputStream fis = new FileInputStream(file); InputStreamReader isr = new InputStreamReader(fis); BufferedReader br = new BufferedReader(isr); char[] char_buffer = new char[(int)file.length()]; br.read(char_buffer); for(int i = 0; i<char_buffer.length; i++){ System.out.print(char_buffer[i]); } br.close(); }catch(Exception ignored){ } } } ``` #### java.util.Properties 类的实际应用 `Properties` 类提供了一种方便的方式,可将应用程序属性存储在两种纯文本文件格式中:属性名/值对或 XML 文件。以下是一个示例: ```java import java.util.*; import java.io.*; public class AppProperties extends Properties { public static final String PROPERTY_A_NAME = "PROPERTY_A_NAME"; public static final String PROPERTY_B_NAME = "PROPERTY_B_NAME"; public static final String PROPERTY_C_NAME = "PROPERTY_C_NAME"; public static final String DEFAULT_PROPERTIES_FILENAME = "DEFAULT_PROPERTIES_FILENAME"; public static final String PROPERTIES_FILE_HEADER = "PROPERTIES_FILE_HEADER"; private static final String PROPERTY_A_VALUE = "Property A's Value"; private static final String PROPERTY_B_VALUE = "Property B's Value"; private static final String PROPERTY_C_VALUE = "Property C's Value"; private static final String DEFAULT_PROPERTIES_FILENAME_VALUE = "app_prop.xml"; private static final String PROPERTIES_FILE_HEADER_VALUE = "Application Properties File"; public AppProperties(){ System.out.println("Attempting to read properties file..."); FileInputStream fis = null; FileOutputStream fos = null; try{ fis = new FileInputStream(DEFAULT_PROPERTIES_FILENAME_VALUE); this.loadFromXML(fis); }catch(Exception e1){ System.out.println("AppProperties: Problem loading properties file."); System.out.println(e1.toString()); System.out.println("Creating new default properties file."); this.setProperty(PROPERTY_A_NAME, PROPERTY_A_VALUE); this.setProperty(PROPERTY_B_NAME, PROPERTY_B_VALUE); this.setProperty(PROPERTY_C_NAME, PROPERTY_C_VALUE); this.setProperty(DEFAULT_PROPERTIES_FILENAME, DEFAULT_PROPERTIES_FILENAME_VALUE); this.setProperty(PROPERTIES_FILE_HEADER, PROPERTIES_FILE_HEADER_VALUE); try{ fos = new FileOutputStream(DEFAULT_PROPERTIES_FILENAME_VALUE); this.storeToXML(fos, PROPERTIES_FILE_HEADER_VALUE); }catch(Exception e2){ System.out.println("AppProperties: Problem creating default properties file."); System.out.println(e2.toString()); }finally{ if(fis != null){ try{ fis.close(); }catch(Exception ignored){ } } if(fos != null){ try{ fos.close(); }catch(Exception ignored){ } } } } } } ``` ```java public class PropertiesTesterApp { public static void main(String[] args){ AppProperties properties = new AppProperties(); System.out.println(properties.getProperty(properties.PROPERTY_A_NAME)); } } ``` 当创建 `AppProperties` 对象时,会尝试打开并读取默认的属性文件。若文件不存在或无法打开,会初始化一组默认属性并创建属性文件。 #### RandomAccessFile 类的使用 `RandomAccessFile` 可用于读写字节、字符和基本类型,但不能读写对象。它提供了 `seek()` 方法,允许在文件中前后移动到任意位置。 ##### 项目需求 假设要创建一个 Java 适配器,用于访问遗留系统的固定长度记录数据文件。项目需求如下: - **目标**: - 展示使用 `RandomAccessFile` 类进行文件 I/O 操作的能力。 - 展示实现非平凡接口的能力。 - 展示将低级异常转换为高级、用户定义的应用程序特定异常抽象的能力。 - 展示通过对象同步协调文件 I/O 操作的能力。 - **任务**:作为零售书店 IT 部门的初级程序员,CEO 希望使用 Java 技术将遗留系统迁移到 Web。第一步是为现有的遗留数据存储创建 Java 适配器。根据接口定义、示例遗留数据文件和遗留数据文件模式定义,编写一个 Java 类作为遗留数据文件的适配器对象。 - **已知条件**: - 指定适配器操作的 Java 接口文件。 - 遗留数据文件模式定义。 - 示例遗留数据文件。 遗留数据文件包含三个部分: | 部分 | 描述 | | ---- | ---- | | 文件标识部分 | 一个两字节的值,用于标识文件为数据文件。 | | 模式描述部分 | 紧随第一部分,包含数据部分每个字段的文本名称和两字节的字段长度。 | | 数据部分 | 包含固定字段长度的记录数据元素,按照以下模式排列: | | 字段名称 | 长度(字节) | 描述 | | ---- | ---- | ---- | | deleted | 1 | 数值 - 0 表示有效,1 表示已删除 | | title | 50 | 文本 - 书籍标题 | | author | 50 | 文本 - 作者全名 | | pub_code | 4 | 数值 - 出版商代码 | | ISBN | 13 | 文本 - 国际标准书号 | | price | 8 | 文本 - 零售价格,格式为:$nnnn.nn | | qoh | 4 | 数值 - 库存数量 | ##### 项目实现思路 - **从小处着手**:编写一个小程序,读取文件的前两个字节并将其转换为数字,以确定文件标识符的值。 ```mermaid graph TD; A[开始] --> B[创建 RandomAccessFile 对象]; B --> C[将文件指针定位到文件开头]; C --> D[读取前两个字节并转换为数字]; D --> E[输出文件标识符的值]; E --> F[结束]; ``` - **逐步分析**:尝试读取文件的其余部分,至少先读取完整的标题和一条完整的记录,同时对标题和记录长度进行详细分析。 - **实现适配器类**:从 `LegacyDatafileInterface` 中指定的 `readRecord()` 方法开始,逐步创建适配器类。 ##### 代码实现 ```java import java.io.*; import java.util.*; public class DataFileAdapter implements LegacyDatafileInterface { private static final short FILE_IDENTIFIER = 378; private static final int HEADER_LENGTH = 54; private static final int RECORDS_START = 54; private static final int RECORD_LENGTH = 130; private static final int FIELD_COUNT = 7; private static final short DELETED_FIELD_LENGTH = 1; private static final short TITLE_FIELD_LENGTH = 50; private static final short AUTHOR_FIELD_LENGTH = 50; private static final short PUB_CODE_FIELD_LENGTH = 4; private static final short ISBN_FIELD_LENGTH = 13; private static final short PRICE_FIELD_LENGTH = 8; private static final short QOH_FIELD_LENGTH = 4; private static final String DELETED_STRING = "deleted"; private static final String TITLE_STRING = "title"; privat ```
corwn 最低0.47元/天 解锁专栏
赠100次下载
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

李_涛

知名公司架构师
拥有多年在大型科技公司的工作经验,曾在多个大厂担任技术主管和架构师一职。擅长设计和开发高效稳定的后端系统,熟练掌握多种后端开发语言和框架,包括Java、Python、Spring、Django等。精通关系型数据库和NoSQL数据库的设计和优化,能够有效地处理海量数据和复杂查询。
最低0.47元/天 解锁专栏
赠100次下载
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看
立即解锁

专栏目录

最新推荐

【Shopee上架工具市场调研指南】:市场需求评估与产品迭代指导

![【Shopee上架工具市场调研指南】:市场需求评估与产品迭代指导](https://www.dny321.com/Resource/News/2024/04/26/0e8a228b87864f3db72fc87308bd25f7.png) # 摘要 本文针对Shopee平台的上架工具进行市场研究、产品迭代策略和功能开发指南的全面分析,并探讨了市场推广和用户反馈循环的实践。首先评估了市场需求,分析了市场细分、目标用户定位以及竞争环境。随后,介绍了产品迭代的概念、原则和过程,强调了在迭代中管理风险的重要性。在功能开发章节中,详细阐述了功能规划、实现及测试,并强调了用户体验和界面设计的关键性。

【管理策略探讨】:掌握ISO 8608标准在路面不平度控制中的关键

![【管理策略探讨】:掌握ISO 8608标准在路面不平度控制中的关键](https://assets.isu.pub/document-structure/221120190714-fc57240e57aae44b8ba910280e02df35/v1/a6d0e4888ce5e1ea00b7cdc2d1b3d5bf.jpeg) # 摘要 本文全面概述了ISO 8608标准及其在路面不平度测量与管理中的重要性。通过深入讨论路面不平度的定义、分类、测量技术以及数据处理方法,本文强调了该标准在确保路面质量控制和提高车辆行驶安全性方面的作用。文章还分析了ISO 8608标准在路面设计、养护和管理

ESP8266小电视性能测试与调优秘籍:稳定运行的关键步骤(专家版)

![ESP8266小电视性能测试与调优秘籍:稳定运行的关键步骤(专家版)](https://www.espboards.dev/img/lFyodylsbP-900.png) # 摘要 本文全面探讨了ESP8266小电视的基本概念、原理、性能测试、问题诊断与解决以及性能调优技巧。首先,介绍了ESP8266小电视的基本概念和工作原理,随后阐述了性能测试的理论基础和实际测试方法,包括测试环境的搭建和性能测试结果的分析。文章第三章重点描述了性能问题的诊断方法和常见问题的解决策略,包括内存泄漏和网络延迟的优化。在第四章中,详细讨论了性能调优的理论和实践,包括软件和硬件优化技巧。最后,第五章着重探讨了

英语学习工具开发总结:C#实现功能与性能的平衡

# 摘要 本文探讨了C#在英语学习工具中的应用,首先介绍了C#的基本概念及在英语学习工具中的作用。随后,详细分析了C#的核心特性,包括面向对象编程和基础类型系统,并探讨了开发环境的搭建,如Visual Studio的配置和.NET框架的安装。在关键技术部分,本文着重论述了用户界面设计、语言学习模块的开发以及多媒体交互设计。性能优化方面,文章分析了性能瓶颈并提出了相应的解决策略,同时分享了实际案例分析。最后,对英语学习工具市场进行了未来展望,包括市场趋势、云计算和人工智能技术在英语学习工具中的应用和创新方向。 # 关键字 C#;英语学习工具;面向对象编程;用户界面设计;性能优化;人工智能技术

SSD加密技术:确保数据安全的关键实现

![固态硬盘SSD原理详细介绍,固态硬盘原理详解,C,C++源码.zip](https://pansci.asia/wp-content/uploads/2022/11/%E5%9C%96%E8%A7%A3%E5%8D%8A%E5%B0%8E%E9%AB%94%EF%BC%9A%E5%BE%9E%E8%A8%AD%E8%A8%88%E3%80%81%E8%A3%BD%E7%A8%8B%E3%80%81%E6%87%89%E7%94%A8%E4%B8%80%E7%AA%BA%E7%94%A2%E6%A5%AD%E7%8F%BE%E6%B3%81%E8%88%87%E5%B1%95%E6%9C%9

【STM32f107vc多线程网络应用】:多线程应用的实现与管理之道

# 摘要 本文旨在系统性介绍STM32f107vc微控制器的多线程基础及其在网络应用中的实践和高级技巧。文章首先概述了多线程的基本理论和网络协议的原理,接着深入探讨了在STM32f107vc平台上的多线程编程实践,包括线程的创建、管理以及同步问题的处理。此外,本文还介绍了网络编程的实践,特别是TCP/IP协议栈的移植和配置,以及多线程环境下的客户端和服务器的实现。文中还探讨了性能优化、容错机制、安全性考虑等高级技巧,并通过案例研究详细分析了STM32f107vc多线程网络应用的实现过程和遇到的挑战。最后,展望了STM32f107vc多线程技术和网络编程的发展趋势,尤其是在物联网和嵌入式系统中的

STM32H743IIT6单片机性能调优

![STM32H743IIT6单片机性能调优](https://community.st.com/t5/image/serverpage/image-id/57651i8E58C576320D40EA/image-size/large/is-moderation-mode/true?v=v2&px=999) # 摘要 本文全面探讨了STM32H743IIT6单片机的性能调优策略,从理论基础到实践应用进行了详细分析。首先介绍了性能调优的基本概念、系统架构与性能关系,以及性能评估工具与方法。随后,文章深入到软件性能优化实践,涵盖代码优化、中断处理性能提升以及电源管理策略。硬件性能优化实践部分,重

【Swing资源管理】:避免内存泄漏的实用技巧

![【Swing资源管理】:避免内存泄漏的实用技巧](https://opengraph.githubassets.com/a6710ff2c86c331c13363554d00aab3dd898536c00e1344fa99ef3cd2923e717/daggerok/findbugs-example) # 摘要 Swing资源管理对于提高Java桌面应用程序的性能和稳定性至关重要。本文首先阐述了Swing资源管理的重要性,紧接着深入探讨了内存泄漏的成因和原理,包括组件和事件模型以及不恰当的事件监听器和长期引用所导致的问题。本文还对JVM的垃圾回收机制进行了概述,介绍了Swing内存泄漏检

【驱动安装自动化】:富士施乐S2220打印机驱动自动安装脚本与详细指南

# 摘要 本文系统地介绍了驱动安装自动化的重要性,并以富士施乐S2220打印机驱动为例,详细阐述了自动化脚本编写的基础理论和实现过程。文章首先强调了自动化安装的必要性和优势,随后对打印机的技术参数以及官方提供的驱动下载与安装方法进行了介绍。接着,文章详细探讨了自动化脚本的基本理论、编写环境、工具选择以及常用脚本语言的比较和选择。在此基础上,本文重点讲述了富士施乐S2220打印机驱动自动安装脚本的实现,包括脚本的初始化、环境配置、主体逻辑实现、监控、异常处理、测试和优化。最后,文章通过不同操作系统下的应用实例和大规模部署案例分析,展示了自动化脚本的实际应用效果,并讨论了常见问题的解决和预防措施。

【智能调度系统的构建】:基于矢量数据的地铁调度优化方案,效率提升50%

# 摘要 随着城市地铁系统的迅速发展,智能调度系统成为提升地铁运营效率与安全的关键技术。本文首先概述了智能调度系统的概念及其在地铁调度中的重要性。随后,文章深入探讨了矢量数据在地铁调度中的应用及其挑战,并回顾了传统调度算法,同时提出矢量数据驱动下的调度算法创新。在方法论章节中,本文讨论了数据收集、处理、调度算法设计与实现以及模拟测试与验证的方法。在实践应用部分,文章分析了智能调度系统的部署、运行和优化案例,并探讨了系统面临的挑战与应对策略。最后,本文展望了人工智能、大数据技术与边缘计算在智能调度系统中的应用前景,并对未来研究方向进行了展望。 # 关键字 智能调度系统;矢量数据;调度算法;数据