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=.:运行当前包中所有 Benchmark* 函数go test -bench=BenchmarkSort:只运行名为 BenchmarkSort 的测试go test -bench=^BenchmarkMap$:精确匹配函数名(用正则锚点避免模糊匹配)默认情况下,每个基准函数会运行至少 1 次,并根据耗时自动调整迭代次数(b.N),使总运行时间接近 1 秒,从而获得更稳定的平均单次耗时。
Go 会动态设置 b.N,你必须将其用于被测逻辑的外层循环,否则结果无意义:
for i := 0; i
for i := 0; i (固定次数,无法反映真实吞吐量)
如需在每次迭代前准备数据(避免干扰),可将初始化逻辑放在 b.ResetTimer() 之前;若想排除初始化开销,用 b.StopTimer() 和 b.StartTimer() 手动控制计时区间。
添加 -benchmem 参数可显示每次操作的内存分配次数和字节数:
go test -bench=. -benchmemBenchmarkSort-8 1000000 1245 ns/op 0 B/op 0 allocs/op
其中 ns/op 是纳秒级单次耗时,B/op 是每次操作分配的字节数,allocs/op 是每次操作的内存分配次数——这些是优化内存敏感型代码的关键依据。