Go中运行基准测试需用go test -bench,函数名以Benchmark开头且接收*testing.B参数,循环必须用b.N确保结果准确。

在 Go 中运行基准测试,只需使用 go test 命令配合特定参数,就能自动发现并执行以 Benchmark 开头的函数,测量代码执行时间、内存分配等性能指标。
确保函数签名符合基准测试规范
基准测试函数必须定义在 *testing.B 类型的参数上,且名称以 Benchmark 开头(首字母大写),否则 go test 不会识别:
- 正确写法:
func BenchmarkSort(b *testing.B) { ... } - 错误写法:
func benchmarkSort(b *testing.B) { ... }(小写开头)或func BenchmarkSort() { ... }(缺少*testing.B参数)
用 go test -bench 运行基准测试
在包目录下执行以下命令即可运行所有基准测试:
-
go test -bench=.:运行当前包中所有Benchmark*函数 -
go test -bench=BenchmarkSort:只运行名为BenchmarkSort的测试 -
go test -bench=^BenchmarkMap$:精确匹配函数名(用正则锚点避免模糊匹配)
默认情况下,每个基准函数会运行至少 1 次,并根据耗时自动调整迭代次数(b.N),使总运行时间接近 1 秒,从而获得更稳定的平均单次耗时。
立即学习“go语言免费学习笔记(深入)”;
在函数体内正确使用 b.N 控制循环
Go 会动态设置 b.N,你必须将其用于被测逻辑的外层循环,否则结果无意义:
- ✅ 正确:
for i := 0; i - ❌ 错误:
for i := 0; i (固定次数,无法反映真实吞吐量)
如需在每次迭代前准备数据(避免干扰),可将初始化逻辑放在 b.ResetTimer() 之前;若想排除初始化开销,用 b.StopTimer() 和 b.StartTimer() 手动控制计时区间。
查看详细性能数据(含内存分配)
添加 -benchmem 参数可显示每次操作的内存分配次数和字节数:
go test -bench=. -benchmem- 输出示例:
BenchmarkSort-8 1000000 1245 ns/op 0 B/op 0 allocs/op
其中 ns/op 是纳秒级单次耗时,B/op 是每次操作分配的字节数,allocs/op 是每次操作的内存分配次数——这些是优化内存敏感型代码的关键依据。











