Java如何基于IO流实现同一文件读写操作
1、注意事项
众所周知,对一个文件进行读写操作时,我们需要创建对应的输入流和输出流
但需要注意的是,读写操作不能同时进行(边读边写),即不能同时打开输入流和输出流,直白一点说就是不能同时对同一个文件的输入流和输出流进行赋值,否则影响文件进行正常的读写操作。如果是不同的文件,则可以边读边写。
2、那么我们怎么对同一个文件进行读写操作呢?
不能边读边写,但是可以先读后写,先写后读。
a、先读后写
打开输入流,对文件进行读操作,操作完成之后把输入流关掉(注意一定要关掉)。然后再打开输出流,对文件进行写操作,操作完成之后再把输出流关掉。
b、先写后读
原理同上
3、案例(代码)
package com.yl.homework.io;
import java.io.*;
import java.util.ArrayList;
/**
* (字符流)读取一个文本文件,每行都追加一个“好”,在文件结尾再追加“完毕”。
*/
public class Test3 {
public static void main(String[] args) {
//文件对象
File file=new File("H:\\ioText\\homework.txt");
//字符缓冲流
BufferedReader bufferedReader=null;
BufferedWriter bufferedWriter=null;
//存储读取的内容
ArrayList<String> arrayList=new ArrayList<>();
try {
//打开输入流
bufferedReader=new BufferedReader(new FileReader(file));
//存储读取内容
String content="";
//读取数据
while ((content=bufferedReader.readLine())!=null){
System.out.println(content);
//每行都追加一个“好”
content+="好";
//把内容存入arrayList
arrayList.add(content);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally {
//关闭流
try {
bufferedReader.close();
} catch (IOException e) {
e.printStackTrace();
}
}
try {
//打开输出流
bufferedWriter=new BufferedWriter(new FileWriter(file));
//遍历arrayList
for (int i=0;i<arrayList.size();i++){
//判断是不是最后一行
if (i==arrayList.size()-1){
//写数据
bufferedWriter.write(arrayList.get(i));
//刷新
bufferedWriter.flush();
}else{
//写数据
bufferedWriter.write(arrayList.get(i));
//换行
bufferedWriter.newLine();
//刷新
bufferedWriter.flush();
}
}
//在文件结尾再追加“完毕”
bufferedWriter.write("完毕");
//刷新文件
bufferedWriter.flush();
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
//关闭流
bufferedWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
利用Spring Cloud Config结合Bus实现分布式配置中心的步骤
这篇文章主要介绍了利用Spring Cloud Config结合Bus实现分布式配置中心的相关资料,文中通过示例代码将实现的步骤一步步介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友下面来一起看看吧2018-05-05
Java中使用@CrossOrigin和Proxy解决跨域问题详解
这篇文章主要介绍了Java中使用@CrossOrigin和Proxy解决跨域问题详解,在Web开发中,如果前端页面和后端接口不在同一个域名下,就会发生跨域请求的问题,同源策略是浏览器的一种安全策略,它限制了来自不同源的客户端脚本在浏览器中运行时的交互,需要的朋友可以参考下2023-12-12
SpringCloud zookeeper作为注册中心使用介绍
ZooKeeper由雅虎研究院开发,是Google Chubby的开源实现,后来托管到Apache,于2010年11月正式成为Apache的顶级项目。ZooKeeper是一个经典的分布式数据一致性解决方案,致力于为分布式应用提供一个高性能、高可用,且具有严格顺序访问控制能力的分布式协调服务2022-11-11
idea2020.1版本git提交项目到github上的方法
这篇文章主要介绍了idea2020.1版本git提交项目到github上的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2020-06-06


最新评论