Go语言基准测试自动运行多轮并计算平均性能,通过b.N动态调整迭代次数以稳定结果,输出每操作耗时等指标;编写时需在example_test.go中定义如BenchmarkAdd函数,使用go test -bench=.执行,可选-benchtime和-count参数控制运行时长与重复次数,同时应避免编译器优化影响,确保结果准确。

Go语言的基准测试(Benchmark)会自动运行多轮并给出平均性能数据,无需手动控制轮数。测试框架通过逐步增加调用量来稳定结果,最终输出每操作耗时、内存分配等指标。
在example_test.go中添加一个基准测试函数:
func BenchmarkAdd(b *testing.B) {
for i := 0; i < b.N; i++ {
add(1, 2)
}
}
func add(a, b int) int {
return a + b
}
b.N由测试框架自动设定,表示目标迭代次数。Go会动态调整b.N直到统计结果稳定。
立即学习“go语言免费学习笔记(深入)”;
执行命令:
go test -bench=.
输出示例:
BenchmarkAdd-8 1000000000 0.325 ns/op
其中0.325 ns/op就是单次操作的平均耗时,已自动计算完成。
可通过参数调整测试行为:
组合使用:
go test -bench=. -benchtime=500ms -count=5
这会让每个基准至少运行500毫秒,并重复5轮,最终显示每次的平均值。
若返回值未被使用,编译器可能优化掉实际计算。应使用b.ReportAllocs()和blackhole变量防止误判:
func BenchmarkAddSafe(b *testing.B) {
var result int
for i := 0; i < b.N; i++ {
result = add(1, 2)
}
_ = result // 确保结果被“使用”
}
基本上就这些。Go的
testing.B
以上就是Golang基准测试运行多轮并平均结果示例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号