bufferedreaderbufferedreader 是缓冲字符输入流。它继承于reader。

bufferedreader 的作用是为其他字符输入流添加一些缓冲功能。

创建bufferreader时,我们会通过它的构造函数指定某个reader为参数。bufferreader会将该reader中的数据分批读取,每次读取一部分到缓冲中;操作完缓冲中的这部分数据之后,再从reader中读取下一部分的数据。

为什么需要缓冲呢?原因很简单,效率问题!缓冲中的数据实际上是保存在内存中,而原始数据可能是保存在硬盘或nandflash中;而我们知道,从内存中读取数据的速度比从硬盘读取数据的速度至少快10倍以上。

那干嘛不干脆一次性将全部数据都读取到缓冲中呢?第一,读取全部的数据所需要的时间可能会很长。第二,内存价格很贵,容量不想硬盘那么大。

示例:

import java.io.bufferedreader;
import java.io.bytearrayinputstream;
import java.io.file;
import java.io.inputstream;
import java.io.filereader;
import java.io.ioexception;
import java.io.filenotfoundexception;
import java.lang.securityexception;
public class bufferedreadertest {
private static final int len = 5;
public static void main(string[] args) {
testbufferedreader() ;
}
/**
* bufferedreader的api测试函数
*/
private static void testbufferedreader() {
// 创建bufferedreader字符流,内容是arrayletters数组
try {
file file = new file("bufferedreader.txt");
bufferedreader in =
new bufferedreader(
new filereader(file));
// 从字符流中读取5个字符。“abcde”
for (int i=0; i
// 若能继续读取下一个字符,则读取下一个字符
if (in.ready()) {
// 读取“字符流的下一个字符”
int tmp = in.read();
system.out.printf("%d : %c\n", i, tmp);
}
}
// 若“该字符流”不支持标记功能,则直接退出
if (!in.marksupported()) {
system.out.println("make not supported!");
return ;
}
// 标记“当前索引位置”,即标记第6个位置的元素--“f”
// 1024对应marklimit
in.mark(1024);
// 跳过22个字符。
in.skip(22);
// 读取5个字符
char[] buf = new char[len];
in.read(buf, 0, len);
system.out.printf("buf=%s\n", string.valueof(buf));
// 读取该行剩余的数据
system.out.printf("readline=%s\n", in.readline());
// 重置“输入流的索引”为mark()所标记的位置,即重置到“f”处。
in.reset();
// 从“重置后的字符流”中读取5个字符到buf中。即读取“fghij”
in.read(buf, 0, len);
system.out.printf("buf=%s\n", string.valueof(buf));
in.close();
} catch (filenotfoundexception e) {
e.printstacktrace();
} catch (securityexception e) {
e.printstacktrace();
} catch (ioexception e) {
e.printstacktrace();
}
}
}

程序中读取的bufferedreader.txt的内容如下:

abcdefghijklmnopqrstuvwxyz

0123456789

abcdefghijklmnopqrstuvwxyz

运行结果:

0 : a

1 : b

2 : c

3 : d

4 : e

buf=01234

readline=56789

buf=fghij

bufferedwriterbufferedwriter 是缓冲字符输出流。它继承于writer。

bufferedwriter 的作用是为其他字符输出流添加一些缓冲功能。

bufferedwriter通过字符数组来缓冲数据,当缓冲区满或者用户调用flush()函数时,它就会将缓冲区的数据写入到输出流中。

示例:

import java.io.bufferedwriter;
import java.io.file;
import java.io.outputstream;
import java.io.filewriter;
import java.io.ioexception;
import java.io.filenotfoundexception;
import java.lang.securityexception;
import java.util.scanner;
public class bufferedwritertest {
private static final int len = 5;
// 对应英文字母“abcdefghijklmnopqrstuvwxyz”
//private static final char[] arrayletters = "abcdefghijklmnopqrstuvwxyz";
private static final char[] arrayletters = new char[] {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
public static void main(string[] args) {
testbufferedwriter() ;
}
/**
* bufferedwriter的api测试函数
*/
private static void testbufferedwriter() {
// 创建“文件输出流”对应的bufferedwriter
// 它对应缓冲区的大小是16,即缓冲区的数据>=16时,会自动将缓冲区的内容写入到输出流。
try {
file file = new file("bufferwriter.txt");
bufferedwriter out =
new bufferedwriter(
new filewriter(file));
// 将arrayletters数组的前10个字符写入到输出流中
out.write(arrayletters, 0, 10);
// 将“换行符\n”写入到输出流中
out.write('\n');
out.flush();
//readuserinput() ;
out.close();
} catch (filenotfoundexception e) {
e.printstacktrace();
} catch (securityexception e) {
e.printstacktrace();
} catch (ioexception e) {
e.printstacktrace();
}
}
/**
* 读取用户输入
*/
private static void readuserinput() {
system.out.println("please input a text:");
scanner reader=new scanner(system.in);
// 等待一个输入
string str = reader.next();
system.out.printf("the input is : %s\n", str);
}
}

运行结果: 生成文件“bufferwriter.txt”,文件的内容是“abcdefghij”。