基准测试通过testing.B循环执行代码以测量性能。例如,BenchmarkSort1000测试对1000个元素排序的耗时,识别性能瓶颈。

Go语言的基准测试(benchmark)是评估函数性能随输入规模变化的有效方式。通过
testing包中的基准测试功能,可以精确测量代码在不同数据量下的运行时间,帮助识别性能瓶颈。
编写基本的基准测试
基准测试函数以
Benchmark开头,接收
*testing.B参数。测试会自动循环执行目标代码多次,以获得稳定的计时结果。
例如,测试一个排序函数:
func BenchmarkSort1000(b *testing.B) { data := make([]int, 1000) for i := 0; i测试多个输入规模
为了观察性能如何随输入增长而变化,应为不同规模的数据编写多个基准函数。
立即学习“go语言免费学习笔记(深入)”;
常见做法是命名中包含数据大小,便于对比:
- BenchmarkSort100:测试100个元素
- BenchmarkSort1000:测试1000个元素
- BenchmarkSort10000:测试1万元素
运行命令
go test -bench=.将依次执行所有基准,并输出每种规模下的纳秒级耗时(如
125 ns/op)。
使用benchmem和pprof分析资源消耗
添加
-benchmem标志可显示每次操作的内存分配次数和字节数: go test -bench=Sort -benchmem
若发现某规模下内存突增或操作变慢,可用
pprof进一步分析: go test -bench=Sort10000 -cpuprofile=cpu.out go tool pprof cpu.out
这能可视化热点函数,判断是否算法复杂度上升或存在不必要的内存分配。
基本上就这些。通过系统性地覆盖多种输入规模,Go的基准测试能清晰展现程序的性能趋势,帮助写出更高效的代码。











