Golang 中的 bufio 包详解(二):bufio.Reader

bufio.Reader

bufio.Reader 是一个带有缓冲区的 io.Reader 接口的实现,提供了一系列方法来帮助读取数据。使用 bufio.Reader 可以减少 I/O 操作,降低读取数据的时间和资源开销。主要特征是它会在内存中存储从底层 io.Reader 中读取到的数据,然后先从内存缓冲区中读取数据,这样可以减少访问底层 io.Reader 对象的次数以及减轻操作系统的压力。结构体定义和对应的方法如下:

type Reader struct {
	buf          []byte
	rd           io.Reader // reader provided by the client
	r, w         int       // buf read and write positions
	err          error
	lastByte     int // last byte read for UnreadByte; -1 means invalid
	lastRuneSize int // size of last rune read for UnreadRune; -1 means invalid
}

下面是 bufio.Reader 的一些主要方法:

  • func (b *Reader) Read(p []byte) (n int, err error):从缓冲区中读取数据到 p 中,返回读取的字节数和可能的读取错误。如果 p 的长度大于缓冲区的大小,则会触发缓冲区的扩容操作。
  • func (b *Reader) ReadByte() (byte, error):从缓冲区中读取一个字节,并返回该字节和可能发生的错误信息。
  • func (b *Reader) ReadRune() (r rune, size int, err error):从缓冲区中读取一个 UTF-8 编码的字符,返回该字符和可能发生的错误。如果缓冲区中没有足够的字节来表示一个完整的 UTF-8 字符,则返回一个错误。
  • func (b *Reader) ReadLine() (line []byte, isPrefix bool, err error):从缓冲区中读取一行,并返回该行内容和可能发生的错误。

其他方法就不一一说明了,最好自己去看去使用去体会。

优势

bufio.Reader 提供了带缓冲的读取操作,先在内存中存储通过系统调用读取到的数据,然后从内存缓冲区中读取数据,大大减少了系统调用次数,减轻了操作系统的压力,加快了数据读取速度。

bufio.Reader 提供了很多类型的读取方法,例如 ReadByte()、 ReadRune() 和 ReadLine() 等,使用起来非常方便。

使用示例

简单使用示例如下:

package main

import (
	"bufio"
	"fmt"
	"os"
)

func main() {
	file, err := os.Open("file.txt")
	if err != nil {
		panic(err)
	}
	defer file.Close()

	reader := bufio.NewReader(file)
	buffer := make([]byte, 4)

	for {
		n, err := reader.Read(buffer)
		if err != nil {
			break
		}
		fmt.Print(string(buffer[:n]))
	}
}

使用 NewReader() 方法创建一个 bufio.Reader 实例,然后创建了一个缓冲区 buffer,并在一个循环中使用 Read() 方法从缓冲区中读取数据。

小结

bufio.Reader 提供了带缓冲的读取操作和丰富的读取操作方法,特别是读取大块数据时,使用 bufio.Reader 可以显著提高程序的性能和响应速度。

你可能感兴趣的:(Golang系列知识讲解,golang,开发语言,后端)