答案是基准测试函数名必须以Benchmark开头,接受*testing.B参数,使用go test -bench=.运行,通过b.N控制迭代次数,b.ResetTimer()避免初始化影响,结果中ns/op为每次操作耗时,allocs/op为内存分配次数,B/op为分配字节数。
golang基准测试的编写规则很简单,关键在于函数名必须以
Benchmark
开头,后面紧跟测试名称,例如
BenchmarkMyFunction
。 记住,基准测试是为了衡量代码性能,所以重点在于测试函数的实现。
编写 Golang 基准测试,需要遵循一些约定俗成的规则,特别是函数命名必须以
Benchmark
开头。
为什么我的基准测试没有运行?
最常见的原因是你的基准测试函数名没有以
Benchmark
开头。Golang 的
testing
包会扫描所有以
Benchmark
开头的函数,并将其识别为基准测试用例。 确保函数签名正确:它应该接受一个
*testing.B
类型的参数。 另外,检查你的测试文件是否与被测试的代码在同一个包中,或者是否正确导入了被测试的包。 还有一种可能,你可能不小心使用了
-run
标志运行测试,但没有匹配的基准测试名称。 确保使用
-bench
标志运行基准测试,例如
go test -bench=.
。
如何正确设置基准测试的迭代次数?
testing
包会自动调整基准测试的迭代次数,以便获得可靠的性能数据。 但有时候,你可能需要手动控制迭代次数。 你可以使用
b.N
变量来控制循环次数。 重要的是,不要在循环内部进行不必要的初始化操作,这会影响测试结果的准确性。 例如,如果你的函数需要初始化一些数据,最好在循环外部完成,只在循环内部执行被测试的代码。 此外,使用
b.ResetTimer()
可以重置计时器,避免初始化代码对测试结果的影响。
立即学习“go语言免费学习笔记(深入)”;
func BenchmarkMyFunction(b *testing.B) { // 初始化代码,只执行一次 data := preparedata() b.ResetTimer() // 重置计时器 for i := 0; i < b.N; i++ { // 执行被测试的代码 MyFunction(data) } }
基准测试结果中的 ns/op, allocs/op, 和 B/op 分别代表什么?
ns/op
代表每次操作的平均耗时,单位是纳秒。 这是衡量代码性能的最直接指标。 数值越小,性能越好。
allocs/op
代表每次操作的平均内存分配次数。 过多的内存分配会影响性能,尤其是在高并发场景下。 减少内存分配是优化代码的重要方向。
B/op
代表每次操作的平均内存分配量,单位是字节。 类似于
allocs/op
,减少内存分配量也能提升性能。 理解这些指标有助于你定位性能瓶颈,并针对性地进行优化。 例如,如果
allocs/op
很高,你可能需要考虑使用对象池或复用对象来减少内存分配。
评论(已关闭)
评论已关闭