BufferedReader 是 Java 中通过内部缓冲区提升字符流读取性能的包装类,需包装 Reader 实例(如 InputStreamReader + FileInputStream),推荐显式指定 UTF-8 编码,优先使用 try-with-resources 和 readLine() 按行读取,避免混用读取方法及默认编码导致乱码。

BufferedReader 是 Java 中用于高效读取字符流的包装类,它通过内部缓冲区减少底层 I/O 调用次数,显著提升读取性能。直接用 FileReader 逐字符或逐行读取效率低,而 BufferedReader 加上合适的缓冲大小(默认 8192 字节),能轻松应对大文件、日志、配置等常见文本读取场景。
构造 BufferedReader 的常用方式
BufferedReader 本身不直接关联文件,必须包装一个 Reader 实例:
- 读取文件:用 FileReader 或更推荐的 InputStreamReader + FileInputStream(支持指定编码)
- 读取标准输入:包装 System.in
- 读取字符串:配合 StringReader(适合测试或内存中内容)
示例(推荐 UTF-8 安全写法):
try (BufferedReader reader = new BufferedReader(new InputStreamReader(
new FileInputStream("data.txt"), StandardCharsets.UTF_8))) {
// 后续读取逻辑
}
核心读取方法与典型用法
最常用的是 readLine() —— 一次读取一整行(不含换行符),返回 null 表示流末尾:
立即学习“Java免费学习笔记(深入)”;
- 适合按行处理日志、CSV、配置项等结构化文本
- 注意:空行返回空字符串
"",不是null - 不要在循环条件里重复调用两次
readLine(),容易跳过数据
正确写法:
String line;while ((line = reader.readLine()) != null) {
System.out.println(line);
}
提升性能与避免踩坑的关键点
- 务必使用 try-with-resources:确保 close() 自动调用,防止资源泄漏和缓冲区未刷新
- 不要混用 read() 和 readLine():前者读单字符,后者依赖换行符定位,混合使用会破坏行边界
- 大文件慎用 readLine() 全部加载到 List:可能引发 OOM;建议边读边处理,或配合 Stream API 流式处理(Java 8+)
-
编码必须显式指定:依赖平台默认编码(如 Windows 的 GBK)极易导致中文乱码,始终传入
StandardCharsets.UTF_8
替代方案:Java 8+ 更简洁的写法
如果只是遍历文件所有行,可用 Files.lines(底层仍用 BufferedReader):
try (Streamlines.filter(s -> !s.trim().isEmpty())
.map(String::toUpperCase)
.forEach(System.out::println);
}
代码更函数式,但需注意:Stream 不支持 reset 或随机访问,且必须及时关闭。










