Go语言通过testing包实现基准测试,使用go test -bench命令并将结果重定向到文件可记录性能数据,结合-benchmem可查看内存分配情况。

在Go语言中,基准测试(Benchmark)是通过标准库 testing 包实现的,主要用于测量函数的性能,比如执行时间、内存分配等。要记录和保存基准测试的结果,可以通过以下方式实现。
编写基准测试用例
基准测试函数名以 Benchmark 开头,接收 *testing.B 参数。测试过程中,b.N 会自动调整以获取稳定的性能数据。
示例:
func BenchmarkHello(b *testing.B) {
for i := 0; i < b.N; i++ {
fmt.Sprintf("hello")
}
}
输出结果到文件
Go 的 go test 命令支持将基准测试结果输出为机器可读的格式,便于后续分析。使用 -benchmem 记录内存分配,-bench 指定测试范围,-json 可输出结构化数据。
立即学习“go语言免费学习笔记(深入)”;
常用命令:
-
go test -bench=. -benchmem > bench_result.txt—— 将结果重定向到文本文件 -
go test -bench=. -json > bench_result.json—— 输出JSON格式,适合程序解析
使用专门工具分析性能变化
Go 提供了 benchcmp(旧版)或使用 benchstat 工具来对比不同版本的基准测试结果。
安装 benchstat:
go install golang.org/x/perf/cmd/benchstat@latest
使用步骤:
- 分别运行新旧代码的基准测试,保存结果:
- 用 benchstat 对比:
go test -bench=. -benchmem > old.txt go test -bench=. -benchmem > new.txt
benchstat old.txt new.txt
输出会显示每次操作的时间、内存分配等指标的变化百分比,帮助判断性能是否提升。
自动化记录建议
- 在CI流程中运行基准测试并保存结果文件,用于长期追踪。
- 结合脚本定期运行测试,将结果存入数据库或可视化系统。
- 避免在基准测试中引入额外逻辑,确保测量准确。
基本上就这些。通过标准命令输出结果,并借助工具分析,就能有效记录和比较Golang基准测试的数据。不复杂但容易忽略细节,比如记得加 -benchmem 才能看到内存分配情况。










