Go bytes.Buffer

该文演示了如何在Go中使用bytes.Buffer进行字符串操作,包括初始化、写入数据、从文件读取、写出到文件,以及各种读取方法如Read、ReadByte、ReadRune、ReadBytes和ReadString的使用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

	//声明
	buf1 := bytes.NewBufferString("haha")
	fmtx.Println("buf1:", buf1)
	buf2 := bytes.NewBuffer([]byte("lolo"))
	fmtx.Println("buf2:", buf2)

	//写入
	buf1.WriteString("h2h2")

	//从文件写入
	file, err := os.Open("./test.txt")
	defer file.Close()
	if err != nil {
		fmtx.Println("file-err:", err)
	}
	buf1.ReadFrom(file)
	fmtx.Println("buf1String:", buf1.String())

	//数据写出到file  io.Writer
	f2, err := os.Create("twrite.txt")
	if err != nil {
		fmtx.Println("Create-err:", err)
	}
	buf1.WriteTo(f2)

	//read 读取
	bufRead := bytes.NewBufferString("hello")
	fmt.Println(bufRead.String())
	var sRead = make([]byte, 3)   // 定义读出的[]byte为3,表示一次可读出3个byte
	bufRead.Read(sRead)           // 读出
	fmt.Println(bufRead.String()) // 打印结果为lo,因为前三个被读出了
	fmt.Println(string(sRead))    // 打印结果为hel,读取的是hello的前三个字母

	bufRead.Read(sRead)           // 接着读,但是bufRead之剩下lo,所以只有lo被读出了
	fmt.Println(bufRead.String()) // 打印结果为空
	fmt.Println(string(sRead))    // 打印结果lol,前两位的lo表示的本次的读出,因为bufRead只有两位,后面的l还是上次的读出结果
	// ReadByte
	buf := bytes.NewBufferString("hello")
	fmt.Println(buf.String()) // buf.String()方法是吧buf里的内容转成string,>以便于打印
	b, _ := buf.ReadByte()    // 读取第一个byte,赋值给b
	fmt.Println(buf.String()) // 打印 ello,缓冲器头部第一个h被拿掉
	fmt.Println(string(b))    // 打印 h
	// ReadRune
	buf3 := bytes.NewBufferString("好hello")
	fmt.Println(buf3.String())   // buf.String()方法是吧buf里的内容转成string,>以便于打印
	br, n, _ := buf3.ReadRune()  // 读取第一个rune,赋值给b
	fmt.Println(buf.String())    // 打印 hello
	fmt.Println(string(br))      // 打印中文字: 好,缓冲器头部第一个“好”被拿掉
	fmt.Println(n)               // 打印3,“好”作为utf8储存占3个byte
	brr, n, _ := buf3.ReadRune() // 再读取第一个rune,赋值给b
	fmt.Println(buf3.String())   // 打印 ello
	fmt.Println(string(brr))     // 打印h,缓冲器头部第一个h被拿掉
	fmt.Println(n)               // 打印 1,“h”作为utf8储存占1个byte

	//ReadBytes 需要分隔符
	var d byte = 'e' //分隔符为e
	buf4 := bytes.NewBufferString("hello")
	fmt.Println(buf4.String()) // buf.String()方法是吧buf里的内容转成string,以便于打印
	b4, _ := buf4.ReadBytes(d) // 读到分隔符,并返回给b
	fmt.Println(buf4.String()) // 打印 llo,缓冲器被取走一些数据
	fmt.Println(string(b4))    // 打印 he,找到e了,将缓冲器从头开始,到e的内容都返回给b

	//ReadString 分隔符
	var d5 byte = 'e' //分隔符为e
	buf5 := bytes.NewBufferString("hello")
	fmt.Println(buf5.String())   // buf.String()方法是吧buf里的内容转成string,以便于打印
	b5, _ := buf5.ReadString(d5) // 读到分隔符,并返回给b
	fmt.Println(buf5.String())   // 打印 llo,缓冲器被取走一些数据
	fmt.Println(b5)              // 打印 he,找到e了,将缓冲器从头开始,到e的内容都返回给b

	//Next 依次读出固定长度的内容
	buf6 := bytes.NewBufferString("hello")
	fmt.Println(buf6.String())
	b6 := buf6.Next(2)         // 重头开始,取2个
	fmt.Println(buf6.String()) // 变小了
	fmt.Println(string(b6))    // 打印he
### 关于 `bytes.Buffer` 的使用和方法 在 Go 编程语言中,`bytes.Buffer` 是一个非常实用的工具,用于高效处理字节数据流。它实现了 `io.Writer` 和 `io.Reader` 接口,因此可以作为输入/输出操作的目标或源。 以下是关于 `bytes.Buffer` 的主要功能及其常见用法: #### 创建和初始化 可以通过实例化 `bytes.Buffer` 来创建一个新的缓冲区对象: ```go var buf bytes.Buffer ``` 或者通过直接赋值来初始化: ```go buf := new(bytes.Buffer) ``` 这两种方式都可以用来创建一个空的缓冲区[^1]。 #### 常见方法 1. **写入数据** 使用 `Write` 方法向缓冲区写入字节数组。 ```go data := []byte("Hello, ") buf.Write(data) // 将 "Hello, " 写入缓冲区 ``` 2. **追加字符串** 可以使用 `WriteString` 方法直接将字符串追加到缓冲区。 ```go buf.WriteString("World!") // 追加 "World!" 到缓冲区 ``` 3. **读取数据** 要从缓冲区读取数据,可以调用 `Bytes()` 或 `String()` 方法获取当前的内容。 ```go content := buf.String() // 获取缓冲区中的字符串内容 fmt.Println(content) // 输出: Hello, World! ``` 4. **重置缓冲区** 如果需要清空缓冲区并重新开始,可以使用 `Reset` 方法。 ```go buf.Reset() // 清空缓冲区 fmt.Println(buf.Len()) // 输出: 0 (长度为零) ``` 5. **检查大小和容量** - 使用 `Len()` 方法返回缓冲区中已有的字节数量。 ```go length := buf.Len() ``` - 使用 `Cap()` 方法返回底层切片的总容量。 ```go capacity := buf.Cap() ``` 6. **转换为 Reader** `bytes.Buffer` 实现了 `io.Reader` 接口,可以直接将其传递给其他函数进行进一步处理。 ```go reader := bufio.NewReader(&buf) line, _ := reader.ReadString(',') fmt.Println(line) // 输出: Hello, ``` 7. **与其他 I/O 流交互** 因为 `bytes.Buffer` 同时实现 `io.Writer` 和 `io.Reader`,所以它可以轻松地与标准库中的其他组件集成。例如,可以用作 HTTP 请求体: ```go request, err := http.NewRequest("POST", "http://example.com/api", &buf) if err != nil { log.Fatal(err) } ``` 8. **Unicode 字符串转 ANSI** 结合外部编码包(如 `golang.org/x/text/encoding`),还可以利用 `bytes.Buffer` 处理字符集转换问题[^2]。例如,将 Unicode 字符串转换为 ANSI 格式可能涉及以下逻辑: ```go encoder := simplifiedchinese.GBK.NewEncoder() ansiStr, err := encoder.Bytes([]byte("你好")) if err != nil { log.Fatal(err) } var outputBuffer bytes.Buffer _, err = outputBuffer.Write(ansiStr) if err != nil { log.Fatal(err) } ``` 以上展示了如何灵活运用 `bytes.Buffer` 完成各种任务。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值