使用strings.Builder可高效拼接字符串,避免频繁内存分配。它通过WriteString、WriteByte累积内容,String()生成结果,支持预分配Grow()提升性能,适用于日志、SQL生成等场景,但非并发安全,复用需调用Reset()。

在Go语言中,当需要频繁拼接字符串时,使用strings.Builder能显著提升性能。相比直接使用+=或fmt.Sprintf,Builder避免了多次内存分配和不可变字符串的复制开销。
strings.Builder 基本用法
strings.Builder是一个可变的字节序列构建器,适用于高效地构造字符串。它内部维护一个可扩展的字节切片,通过写入操作累积内容,最后调用String()方法生成最终字符串。
常用方法包括:
- WriteString(s string):追加字符串
- WriteByte(c byte):追加单个字节(常用于字符)
- String():返回当前已构建的字符串(只能调用一次后应丢弃实例)
示例代码:
立即学习“go语言免费学习笔记(深入)”;
package mainimport ( "fmt" "strings" )
func main() { var sb strings.Builder parts := []string{"Hello", " ", "World", "!"}
for _, part := range parts { sb.WriteString(part) } result := sb.String() fmt.Println(result) // 输出: Hello World!}
适用场景与性能优势
在循环中拼接大量字符串时,
strings.Builder比传统方式快得多。因为普通字符串拼接每次都会创建新对象,而Builder利用预分配和缓冲机制减少内存拷贝。若提前知道大致长度,可以调用
Grow()预分配空间,进一步提升效率。带预分配的示例:
var sb strings.Builder sb.Grow(1024) // 预分配1024字节for i := 0; i < 100; i++ { sb.WriteString("item") sb.WriteByte(',') } // 去掉末尾多余的逗号 if sb.Len() > 0 { sb.Truncate(sb.Len() - 1) } fmt.Println(sb.String())
注意事项
strings.Builder不是并发安全的,不能在多个goroutine中同时写入。另外,一旦调用了String(),就不应再修改该实例,否则可能导致数据不一致或panic。如果需要复用,可通过
Reset()清空内容,重置内部缓冲。复用示例:
sb.Reset() // 清空内容,可重新使用 sb.WriteString("New start") fmt.Println(sb.String())基本上就这些。合理使用
strings.Builder,能有效优化字符串拼接性能,尤其适合日志组装、动态SQL生成等高频操作场景。不复杂但容易忽略。










