Go语言table-driven基准测试通过testing.B对多组输入数据独立计时,支持算法性能对比与边界case评估;需用b.Run()为每组参数创建子基准,命名含关键参数,并避免预处理污染计时。
Go 语言的 table-driven 基准测试(benchmarks)是验证函数在不同输入规模或数据特征下性能表现的高效方式。它不像单元测试那样只关注“对错”,而是聚焦“快慢”——尤其适合对比算法优化、评估边界 case、发现隐式性能退化。
testing.B 驱动多组数据循环基准测试函数签名固定为 func BenchmarkXxx(*testing.B),其中 *testing.B 提供了计时、迭代控制和报告能力。要测多组数据,只需在 B.Run() 中为每组参数创建子基准:
"100"、"sorted"),便于识别B.ResetTimer() 前做耗时预处理(如生成大数据),否则会污染测量定义一个结构体切片,每项包含输入数据、预期行为(可选)、描述性标签。例如测字符串查找函数:
var benchCases = []struct {
name string
data string
want int
}{
{"short", "hello world", 6},
{"long", stri
ngs.Repeat("a", 10000) + "x", 10000},
{"empty", "", 0},
}
然后遍历运行:
func BenchmarkFindIndex(b *testing.B) {
for _, tc := range benchCases {
b.Run(tc.name, func(b *testing.B) {
b.ReportAllocs() // 可选:记录内存分配
for i := 0; i < b.N; i++ {
_ = findIndex(tc.data, 'x') // 实际被测函数
}
})
}
}
若每次迭代需重建状态(如新建 map、重置 slice),应放在 b.ResetTimer() 之后;若只需一次初始化(如预编译正则),放在 b.ResetTimer() 之前:
b.ResetTimer() 重置计时器和分配计数器,通常放在循环前ResetTimer 前完成,且只做一次执行 go test -bench=. -benchmem:
BenchmarkFindIndex/short-8 10000000 124 ns/op 0 B/op 0 allocs/op 表示每操作平均 124 纳秒,无内存分配/short),方便 -bench=FindIndex/long 单独运行某组-benchmem 显示每次操作的平均内存分配字节数和次数,对排查 GC 压力很关键