如何使用BufferedReader循环读文件
使用BufferedReader(缓存读取流)可以每次读取文件的一行。对于文件内容如果是按行为单位排列的话,则使用BufferedReader来读取文件还是比较方便的。
举例如下
1、BufferedReader读取一行
在F盘下有个txt文件,文件内容为

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循环读每一行
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;
//读取内容为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、注意细节
新手如果没不注意,容易写成:
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循环中, if 语句在做判断时,其实已经读取了一行,而读取的这行没有被打印出来,所以就造成了只打印了一部分。
BufferedReader.rean(buffer)注意事项
最近遇到一个问题
BufferedReader.rean(buffer)
读取数据时,最后一行必须获取到返回值
len=BufferedReader.rean(buffer)
只能取0到len区间的数据,len之后的数据为上次读取过的数据,原因是因为buffer读取时不会清空数组。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
SpringCloud openfeign相互调用实现方法介绍
在springcloud中,openfeign是取代了feign作为负载均衡组件的,feign最早是netflix提供的,他是一个轻量级的支持RESTful的http服务调用框架,内置了ribbon,而ribbon可以提供负载均衡机制,因此feign可以作为一个负载均衡的远程服务调用框架使用2022-11-11
RabbitMq报错reply-code=406 reply-text=PRECONDITION_FAILED
这篇文章主要为大家介绍了RabbitMq报错reply-code=406 reply-text=PRECONDITION_FAILED分析解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-12-12
@Transactional注解:多个事务嵌套时,独立事务处理方式
这篇文章主要介绍了@Transactional注解:多个事务嵌套时,独立事务处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-01-01


最新评论