BufferedReader:从字符输入流读取文本,缓冲字符,以提供字符、数组和行的高效读取,可以指定缓冲区大小,或者可以使用默认大小。默认值足够大,可用于大多数用途
构造方法
BufferedReader(Reader in)
使用字符缓冲输入流将读取的数据写入到ArrayList集合中
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
/*将文件中的数据写入到集合中*/
public class demo2 {
public static void main(String[] args) throws IOException {
ArrayList<String>ay = new ArrayList<>();
/*创建字符缓冲输入流对象*/
BufferedReader br = new BufferedReader(new FileReader("D:\\java的学习\\IO流\\test\\java.txt"));
/*读取数据写入到集合*/
while ((br.readLine())!=null) {
ay.add(br.readLine());
/*将数据写入到集合中*/
}
br.close();/*释放资源*/
for(String x: ay) {
System.out.println(x);
}
}
}
在该文件路径下的文件,里面的数据是有6个hello,而在实际控制台中却只遍历出3个hello,也就是说实际中的6个数据却只存储了3个数据到集合中。
原因:
字符缓冲输入流中的readLine()方法每次读取一行,也可以将它理解为每写readLine()方法,它就会读取一行文字,下一个readLine()方法读取的就是下一行的文字。所以上述程序会出现这种情况是因为在while循环的判断中执行了一次readLine()方法即读取出了一行,而while循环里面的readLine()方法将数据添加到集合中就是另外一行。所以最终的数据是要比实际为文件数据要少
解决方案:
创建字符串遍历收while循环判断中读取到的数据,在给集合添加数据的时候将该字符串对象添加进去即可
代码改进
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
/*将文件中的数据写入到集合中*/
public class demo2 {
public static void main(String[] args) throws IOException {
ArrayList<String>ay = new ArrayList<>();
/*创建字符缓冲输入流对象*/
BufferedReader br = new BufferedReader(new FileReader("D:\\java的学习\\IO流\\test\\java.txt"));
/*读取数据写入到集合*/
String content;/*创建字符串对象用于接收while循环判断中readLine()方法读取到的数据*/
while ((content=br.readLine())!=null) {
ay.add(content);/*将字符串对象添加到集合中*/
/*将数据写入到集合中*/
}
br.close();/*释放资源*/
for(String x: ay) {
System.out.println(x);
}
}
}
如上,使用改进后的代码能够将数据全部存储到集合当中。
小结:
BufferedReader:字符缓冲输入流对象,它的构造方法是BufferedRead(Reader in),即在使用构造方法时需要传入一个FileRead对象用于指定文件路径
BufferedReader的readLine()方法是逐行读取的过程,每使用一次该语句都会往下读取一行