Go基准测试Benchmark

Go语言自带了一个强大的测试框架,其中包括基准测试(Benchmark)功能,基准测试用于测量和评估一段代码的性能。

我们可以通过在Go的测试文件中编写特殊格式的函数来创建基准测试。测试文件的命名遵守原函数名称_test.go 的格式。

基准测试函数的名字必须以"Benchmark"开头,后面跟着的是想要命名的测试名字,函数的唯一参数是一个指向*testing.B的指针。例如:

go 复制代码
func BenchmarkMyFunction(b *testing.B) {
    for i := 0; i < b.N; i++ {
        // 执行你想要测试性能的代码
    }
}

在基准测试函数中,将想要测试的代码放在一个针对b.N的循环中。b.N是一个非常大的数,Go测试框架会自动调整它的值,以使得基准测试函数运行的时间足够长,从而得到更准确的结果。

通过在命令行中运行go test -bench=.来执行基准测试。-bench标志后面跟着的是一个正则表达式,匹配你想要运行的基准测试函数的名字,. 表示匹配所有文件。

shell 复制代码
go test -bench=.

基准测试结果会显示每次操作的平均时间,可以通过这个结果来评估你的代码的性能,或者对比不同版本或不同实现的性能差异。

范例:

go 复制代码
func BenchmarkTest(b *testing.B) {
	str := ""
	for i := 0; i < b.N; i++ {
		str += "a"
	}
}

输出:

shell 复制代码
goos: darwin
goarch: arm64
pkg: awesomeProject3
BenchmarkTest
BenchmarkTest-12    	 1000000	     28001 ns/op
PASS
  • goos: darwin:基准测试运行操作系统
  • goarch: arm64:基准测试运行的处理器架构
  • pkg: awesomeProject3:基准测试运行在的 Go 包
  • BenchmarkTest:基准测试函数名
  • BenchmarkTest-12:基准测试及其并行度。这里是在并行度为 12 的情况下运行。
  • 1000000:基准测试函数运行次数
  • 28001 ns/op:每次运行基准测试函数需要的时间,单位是纳秒。这里是为 28001 纳秒,即 0.028001 毫秒。
  • PASS:表示基准测试通过
相关推荐
南子北游5 分钟前
Python学习(基础语法1)
开发语言·python·学习
张健115640964810 分钟前
使用信号量限制并发数量
开发语言·c++
sjsjsbbsbsn11 分钟前
大模型核心知识总结
java·人工智能·后端
Moment20 分钟前
2026 年,AI 全栈时代到了,前端简历别再只写前端技术了 🫠🫠🫠
前端·后端·面试
糯米团子74928 分钟前
Web Worker
开发语言·前端·javascript
我命由我123451 小时前
JavaScript 开发 - 获取函数名称、获取函数参数数量、获取函数参数名称
开发语言·前端·javascript·css·html·html5·js
白晨并不是很能熬夜1 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
简简单单就是我_hehe2 小时前
后端链路追踪局部采集和全量采集配置说明
java·开发语言
zshs0002 小时前
#从偶发无字幕到补偿探测链路:一次 B 站字幕导入问题的完整收敛过程
java·后端·重构
北京理工大学软件工程2 小时前
C#111
开发语言·c#