Java如何基于IO流實(shí)現(xiàn)同一文件讀寫(xiě)操作
1、注意事項(xiàng)
眾所周知,對(duì)一個(gè)文件進(jìn)行讀寫(xiě)操作時(shí),我們需要?jiǎng)?chuàng)建對(duì)應(yīng)的輸入流和輸出流
但需要注意的是,讀寫(xiě)操作不能同時(shí)進(jìn)行(邊讀邊寫(xiě)),即不能同時(shí)打開(kāi)輸入流和輸出流,直白一點(diǎn)說(shuō)就是不能同時(shí)對(duì)同一個(gè)文件的輸入流和輸出流進(jìn)行賦值,否則影響文件進(jìn)行正常的讀寫(xiě)操作。如果是不同的文件,則可以邊讀邊寫(xiě)。
2、那么我們?cè)趺磳?duì)同一個(gè)文件進(jìn)行讀寫(xiě)操作呢?
不能邊讀邊寫(xiě),但是可以先讀后寫(xiě),先寫(xiě)后讀。
a、先讀后寫(xiě)
打開(kāi)輸入流,對(duì)文件進(jìn)行讀操作,操作完成之后把輸入流關(guān)掉(注意一定要關(guān)掉)。然后再打開(kāi)輸出流,對(duì)文件進(jìn)行寫(xiě)操作,操作完成之后再把輸出流關(guān)掉。
b、先寫(xiě)后讀
原理同上
3、案例(代碼)
package com.yl.homework.io;
import java.io.*;
import java.util.ArrayList;
/**
* (字符流)讀取一個(gè)文本文件,每行都追加一個(gè)“好”,在文件結(jié)尾再追加“完畢”。
*/
public class Test3 {
public static void main(String[] args) {
//文件對(duì)象
File file=new File("H:\\ioText\\homework.txt");
//字符緩沖流
BufferedReader bufferedReader=null;
BufferedWriter bufferedWriter=null;
//存儲(chǔ)讀取的內(nèi)容
ArrayList<String> arrayList=new ArrayList<>();
try {
//打開(kāi)輸入流
bufferedReader=new BufferedReader(new FileReader(file));
//存儲(chǔ)讀取內(nèi)容
String content="";
//讀取數(shù)據(jù)
while ((content=bufferedReader.readLine())!=null){
System.out.println(content);
//每行都追加一個(gè)“好”
content+="好";
//把內(nèi)容存入arrayList
arrayList.add(content);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally {
//關(guān)閉流
try {
bufferedReader.close();
} catch (IOException e) {
e.printStackTrace();
}
}
try {
//打開(kāi)輸出流
bufferedWriter=new BufferedWriter(new FileWriter(file));
//遍歷arrayList
for (int i=0;i<arrayList.size();i++){
//判斷是不是最后一行
if (i==arrayList.size()-1){
//寫(xiě)數(shù)據(jù)
bufferedWriter.write(arrayList.get(i));
//刷新
bufferedWriter.flush();
}else{
//寫(xiě)數(shù)據(jù)
bufferedWriter.write(arrayList.get(i));
//換行
bufferedWriter.newLine();
//刷新
bufferedWriter.flush();
}
}
//在文件結(jié)尾再追加“完畢”
bufferedWriter.write("完畢");
//刷新文件
bufferedWriter.flush();
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
//關(guān)閉流
bufferedWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java出現(xiàn)中文亂碼問(wèn)題分析及解決方案
在Java開(kāi)發(fā)中,處理中文亂碼是一個(gè)常見(jiàn)的問(wèn)題,由于字符集和編碼的復(fù)雜性,開(kāi)發(fā)者可能面臨各種導(dǎo)致亂碼的情況,正確地處理中文字符集對(duì)于確保應(yīng)用程序的可靠性和國(guó)際化至關(guān)重要,本文給大家介紹了Java中文亂碼分析及解決方案,需要的朋友可以參考下2024-02-02
SpringBoot查詢PGSQL分表后的數(shù)據(jù)的代碼示例
數(shù)據(jù)庫(kù)用的pgsql,在表數(shù)據(jù)超過(guò)100w條的時(shí)候執(zhí)行定時(shí)任務(wù)進(jìn)行了分表,分表后表名命名為原的表名后面拼接時(shí)間,但是我在java業(yè)務(wù)代碼中,我想查詢之前的那條數(shù)據(jù)就查不到了,本文給大家介紹了SpringBoot中如何查詢PGSQL分表后的數(shù)據(jù),需要的朋友可以參考下2024-05-05
利用Spring Cloud Config結(jié)合Bus實(shí)現(xiàn)分布式配置中心的步驟
這篇文章主要介紹了利用Spring Cloud Config結(jié)合Bus實(shí)現(xiàn)分布式配置中心的相關(guān)資料,文中通過(guò)示例代碼將實(shí)現(xiàn)的步驟一步步介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友下面來(lái)一起看看吧2018-05-05
java報(bào)錯(cuò)非法的前向引用問(wèn)題
這篇文章主要介紹了java報(bào)錯(cuò)非法的前向引用問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
Mybatis多參數(shù)及實(shí)體對(duì)象傳遞實(shí)例講解
在使用Mybatis的時(shí)候,經(jīng)常會(huì)有各種各樣的參數(shù)傳遞,不同類型,不同個(gè)數(shù)的參數(shù),下面小編通過(guò)例子給大家講解下Mybatis多參數(shù)及實(shí)體對(duì)象傳遞,一起看看吧2016-12-12
Java中使用@CrossOrigin和Proxy解決跨域問(wèn)題詳解
這篇文章主要介紹了Java中使用@CrossOrigin和Proxy解決跨域問(wèn)題詳解,在Web開(kāi)發(fā)中,如果前端頁(yè)面和后端接口不在同一個(gè)域名下,就會(huì)發(fā)生跨域請(qǐng)求的問(wèn)題,同源策略是瀏覽器的一種安全策略,它限制了來(lái)自不同源的客戶端腳本在瀏覽器中運(yùn)行時(shí)的交互,需要的朋友可以參考下2023-12-12
SpringCloud zookeeper作為注冊(cè)中心使用介紹
ZooKeeper由雅虎研究院開(kāi)發(fā),是Google Chubby的開(kāi)源實(shí)現(xiàn),后來(lái)托管到Apache,于2010年11月正式成為Apache的頂級(jí)項(xiàng)目。ZooKeeper是一個(gè)經(jīng)典的分布式數(shù)據(jù)一致性解決方案,致力于為分布式應(yīng)用提供一個(gè)高性能、高可用,且具有嚴(yán)格順序訪問(wèn)控制能力的分布式協(xié)調(diào)服務(wù)2022-11-11
一文總結(jié)RabbitMQ中的消息確認(rèn)機(jī)制
RabbitMQ消息確認(rèn)機(jī)制指的是在消息傳遞過(guò)程中,發(fā)送方發(fā)送消息后,接收方需要對(duì)消息進(jìn)行確認(rèn),以確保消息被正確地接收和處理,本文為大家整理了RabbitMQ中的消息確認(rèn)機(jī)制,需要的可以參考一下2023-06-06
idea2020.1版本git提交項(xiàng)目到github上的方法
這篇文章主要介紹了idea2020.1版本git提交項(xiàng)目到github上的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2020-06-06

