Go 语言 testing 包支持内存基准测试,需调用 b.ReportAllocs() 启用堆内存分配统计,否则输出缺失 B/op 和 allocs/op 两列。
Go 语言自带的 testing 包支持内存基准测试(memory benchmark),能精确统计函数执行过程中的堆内存分配次数和字节数,是定位内存热点、优化 GC 压力的关键手段。
在基准测试函数中调用 b.ReportAllocs(),即可开启内存统计。该调用必须在 b.ResetTimer() 之前或之后(但通常放在开头),它不会影响计时,只启用分配计数器。
go test -bench 输出中将缺失 B/op 和 allocs/op 两列func BenchmarkParseJSON(b *testing.B) {
b.ReportAllocs() // 关键:开启内存统计
b.ResetTimer()
for i := 0; i < b.N; i++ {
parseData() // 被测逻辑
}
}使用标准命令运行:
go test -bench=BenchmarkParseJSON -benchmem
输出类似:
BenchmarkParseJSON-8 1000000 1241245 ns/op 320 B/op 8 allocs/op
320 B/op:每次调用平均分配 320 字节堆内存8 allocs/op:每次调用触发 8 次堆内存分配(如 make、new、切片扩容、字符串转字节等)仅看总量不够,需结合 pprof 查分配栈:
runtime.GC() 避免前序干扰(可选)-cpuprofile 或 -memprofile 生成 profile 文件:go test -bench=BenchmarkParseJSON -benchmem -memprofile=mem.out
go tool pprof mem.out (pprof) top (pprof) web可直观看到哪些函数/行号分配最多
make([]T, n)、频繁 fmt.Sprintf、闭包捕获大对象、无意识的值拷贝(如结构体过大传参)sync.Pool 复用临时对象(如缓冲区、解析器实例)make([]int, 0, expectedCap) 避免多次扩容strings.Builder 替代 + 或 fmt.Sprintf 拼接字符串