strings.Builder 比 string += 更快,因为后者每次拼接都需分配新数组并复制,时间复杂度 O(n²),而 Builder 使用可增长 byte 切片,均摊 O(1);预分配和正确 Reset 可进一步提升性能。
因为 string 在 Go 中是不可变的,每次用 += 拼接都会分配新底层数组、复制旧内容,时间复杂度是 O(n²)。而 strings.Builder 内部用可增长的 []byte 缓冲区,只在容量不足时扩容(类似 slice 的 2 倍策略),写入是 O(1) 均摊复杂度。
实操建议:
strings.Builder
b.Grow(n) 预分配空间,避免中间扩容strings.Builder 实例重复调用 String() 后继续写入——虽然合法,但会触发额外内存拷贝(String() 返回的是只读副本)strings.Builder 是 Go 1.10 引入的轻量替代品,专为字符串构建优化;bytes.Buffer 功能更全(支持读、定位、二进制操作),但多一层抽象和接口调用开销。
实操建议:
strings.Builder
bytes.Buffer
strings.Builder 的 Reset() 不清空底层内存,只是重置长度,复用安全且零分配典型错误是把 strings.Builder 当作全局或长生命周期变量反复使用,却不调用 Reset(),导致输出内容不断累积。
示例:
var b strings.Builder
b.WriteString("a")
b.WriteString("b")
fmt.Println(b.String()) // "ab"
b.WriteString("c") // 忘记 Reset()
fmt.Println(b.String()) // "abc" —— 而不是预期的 "c"
正确做法:

Reset()
b.Reset()
strings.Builder 实例Go 编译器(截至 1.22)**不会**将多个 += 自动转成 Builder 或预分配。它只对极简单场景(如固定几项常量拼接)做内联或静态折叠,无法推断动态拼接逻辑。
这意味着:
strings.Builder
string += 在 10+ 次拼接下通常慢 3–5 倍,且内存分配次数显著上升go tool compile -S 查看汇编,可确认无隐式 Builder 插入Reset() 时机——这两处不处理,性能提升会打折扣。