在java里面,把IO大致分成了两类,一类基于字符流,另一类基于字节流.
所有基于字符流的类的基类为Reader和Writer,所有基于字节流的类的基类为InputStream和OutputStream.
当然这两个区别不是完全的,InputStreamReader和OutputStreamWriter是这两条线的桥梁,InputStreamReader将输入的字节流按照指定的编码转换成字符流.
Reader这个类重要的方法就是read方法
//读单个字符
public int read() throws IOException {
char cb[] = new char[1];
if (read(cb, 0, 1) == -1)
return -1;
else
return cb[0];
}
//读len个字符到cbuf里面,从cbuf的off位置开始存储
abstract public int read(char cbuf[], int off, int len) throws IOException;
注意到上面的read方法是一个抽象方法,需要后面的类来实现这个功能,根据不同的需求,高效地实现read方法.
现在来分析BufferedReader的源代码
BufferedReader是基于缓冲的读取方式,因为每次都调用读取磁盘的方法可能有时候会很慢,比如:读取一个文件,一次读取一个字符,每次读取一个字符都会访问一次磁盘,这样的速度可想而知会有多慢。BufferedReader就避免了这种情况,首先将文件读取一部分到内存中的缓冲区,然后若要一个字符一个字符的读取就很快了,只需要直接从内存中获取。既然要缓冲的话,那就要考虑同步的