聊聊為什么要使用BufferedReader讀取File
使用BufferedReader讀取File
Java編程思想一書里面有云,為了提高速度,可以用BufferedReader過濾器類,以提供緩沖區(qū)域。但是這個解釋太簡略了,看了這句話仍然不知道為什么要使用它,于是感覺值得研究一下。
其實只用FileReader也能完成讀取文件的任務。
FileReader有三個用于read的函數(shù)
public int read():每次只read一個字符public int read(char cbuf[], int offset, int length):每次read從offset到offset+length-1的字符,然后放進cbuf中public int read(char cbuf[]):一次性的read出來所有的字符,直接放入cbuf中
這三個read方法,每次調(diào)用一次就會read一次file,進行一次IO。不管是多次read還是一次性的read,都不是很優(yōu)雅的在read文件的方式。多次read必然會產(chǎn)生多次IO,一次性的read如果遇到很大的文件,對內(nèi)存是極不友好的。
于是BufferedReader就顯現(xiàn)出好處來了。BufferedReader使用裝飾器模式,它的IO行為是每次讀進來8k的數(shù)據(jù)到緩沖區(qū),如果需要使用數(shù)據(jù)的時候,再直接從緩沖區(qū)里面拿出數(shù)據(jù)來使用。這樣一來,既提高的讀取速度,又節(jié)省了IO的次數(shù),是一種比較優(yōu)雅的讀取文件的方式。
使用BufferedReader讀取File的代碼舉例
BufferedReader bufferedReader = new BufferedReader(new FileReader("./pom.xml"));
StringBuilder stringBuilder = new StringBuilder();
while ((s = bufferedReader.readLine()) != null) {
stringBuilder.append(s + "\n");
}
System.out.println(stringBuilder.toString());
使用BufferedReader循環(huán)讀文件(新手要注意的細節(jié))
使用BufferedReader(緩存讀取流)可以每次讀取文件的一行。對于文件內(nèi)容如果是按行為單位排列的話,則使用BufferedReader來讀取文件還是比較方便的。
舉例如下
1、BufferedReader讀取一行
在F盤下有個txt文件,文件內(nèi)容為

import java.io.*;
public class test {
public static void main(String[] args) {
BufferedReader br = null;
try {
br = new BufferedReader(new FileReader("F:\\test.txt"));
System.out.println(br.readLine());
} catch (IOException e) {
e.printStackTrace();
}
}
結果為:
哈哈0
2、BufferedReader循環(huán)讀每一行
import java.io.*;
public class test {
public static void main(String[] args) {
BufferedReader br = null;
try {
br = new BufferedReader(new FileReader("F:\\test.txt"));
String text = null;
//讀取內(nèi)容為null則表示讀到了文件末尾
while ((text = br.readLine()) != null) {
System.out.println(text);
}
} catch (IOException e) {
e.printStackTrace();
}
}
結果為:
哈哈0
哈哈1
哈哈2
哈哈3
哈哈4
哈哈5
哈哈6
哈哈7
哈哈8
哈哈9
3、注意細節(jié)
新手如果沒不注意,容易寫成:
import java.io.*;
public class test {
public static void main(String[] args) {
BufferedReader br = null;
try {
br = new BufferedReader(new FileReader("F:\\test.txt"));
String text = null;
//
while (true) {
if (br.readLine() == null) {
break;
}
System.out.println(br.readLine());
}
} catch (IOException e) {
e.printStackTrace();
}
}
結果為:
哈哈1
哈哈3
哈哈5
哈哈7
哈哈9
原因
while (true) {
if (br.readLine() == null) {
break;
}
System.out.println(br.readLine());
}
因為在while循環(huán)中, if 語句在做判斷時,其實已經(jīng)讀取了一行,而讀取的這行沒有被打印出來,所以就造成了只打印了一部分。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
一文帶你理解@RefreshScope注解實現(xiàn)動態(tài)刷新原理
RefeshScope這個注解想必大家都用過,在微服務配置中心的場景下經(jīng)常出現(xiàn),他可以用來刷新Bean中的屬性配置,那大家對他的實現(xiàn)原理了解嗎,它為什么可以做到動態(tài)刷新呢,所以本文小編將給大家詳細介紹@RefreshScope注解實現(xiàn)動態(tài)刷新原理2023-07-07
解決springboot使用logback日志出現(xiàn)LOG_PATH_IS_UNDEFINED文件夾的問題
這篇文章主要介紹了解決springboot使用logback日志出現(xiàn)LOG_PATH_IS_UNDEFINED文件夾的問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04

