使用bufio包可提升Go中I/O效率,通过缓冲减少系统调用。1. bufio.Reader支持按行(ReadString/ReadLine)或定长读取,适用于文件、网络数据处理;2. bufio.Writer将数据暂存内存,缓冲区满或调用Flush时写入,避免频繁写操作;3. 结合Scanner可高效解析输入,如按行或字段分割文本。示例包括读取文件每行、批量写入后刷新、从标准输入读取至空行。关键点:合理设置缓冲大小,写入后必须Flush,Scanner需检查Scan返回值以处理EOF或错误。正确使用能显著提升性能。

在Golang中,bufio 包提供了带缓冲的I/O操作,能显著提升文件或网络读写效率。它通过减少系统调用次数来优化性能,特别适合处理大量小数据块的场景。
使用 bufio.Reader 读取数据
当从文件、网络连接或其他 io.Reader 接口读取数据时,使用 bufio.Reader 可以避免频繁的系统调用。
常见用法包括按行读取或按块读取:
- 使用 ReadString 或 ReadLine 读取单行内容,适合处理日志、配置文件等文本数据。
- 使用 Read 方法读取指定字节数,适用于自定义协议解析。
- 结合 Scanner 更方便地按行、按字段分割数据(底层也是 Reader 实现)。
示例:按行读取文件
立即学习“go语言免费学习笔记(深入)”;
file, _ := os.Open("data.txt")
defer file.Close()
reader := bufio.NewReader(file)
for {
line, err := reader.ReadString('\n')
if err != nil && err != io.EOF {
break
}
fmt.Print(line)
if err == io.EOF {
break
}
}
使用 bufio.Writer 写入数据
bufio.Writer 将数据先写入内存缓冲区,当缓冲区满或显式调用 Flush 时才真正写入底层设备。
这在频繁写小块数据时非常高效,比如写日志、生成大文件等。
- 创建 Writer 时可指定缓冲大小,如 bufio.NewWriterSize(file, 4096)。
- 写完后必须调用 Flush 确保所有数据落盘,否则可能丢失最后部分。
示例:批量写入并刷新
file, _ := os.Create("output.txt")
defer file.Close()
writer := bufio.NewWriter(file)
for i := 0; i < 1000; i++ {
fmt.Fprintln(writer, "line", i)
}
writer.Flush() // 关键步骤:确保数据写入文件
结合 Scanner 高效解析输入
对于标准输入或结构化文本,bufio.Scanner 是最简洁的选择。
它默认按行切分,也可自定义分割函数,适合读取用户输入、解析 CSV、逐词处理等。
- Scanner 自动处理缓冲,API 简洁。
- 遇到错误时通过 Err() 获取具体错误信息。
- 注意:Scan 返回 false 时可能是因为 EOF 或其他错误。
示例:从标准输入读取直到空行
scanner := bufio.NewScanner(os.Stdin)
for scanner.Scan() {
text := scanner.Text()
if text == "" {
break
}
fmt.Println("输入:", text)
}
基本上就这些。合理使用 bufio 能让IO更高效,关键是理解缓冲机制和记得刷新输出。不复杂但容易忽略细节。










