新闻中心
如何在Golang中使用testing.B进行性能测试_Golang testing.B性能测试方法汇总
testing.B用于Go性能测试,通过go test -bench=.运行,可测量函数吞吐量、耗时及内存分配;编写时函数名以Benchmark开头,接收*testing.B参数,b.N由运行时自动调整以稳定测试时长;可用-benchtime设置最短运行时间,-count指定重复次数;调用b.ReportAllocs()输出内存分配情况;使用b.ResetTimer()等控制计时范围,排除初始化开销;通过b.Run()创建子基准测试对比不同场景;需防止编译器优化影响结果,如将结果赋值给全局变量;结合-benchmem和pprof可深入分析性能。

在Go语言中,testing.B 是 testing 包提
供的用于性能基准测试的核心类型。通过 go test -bench=. 命令可以运行这些测试,帮助开发者评估函数的执行效率,比如每秒能执行多少次操作(即吞吐量),以及每次操作消耗的时间和内存资源。
1. 编写基本的性能测试函数
性能测试函数与普通测试函数类似,但函数名以 Benchmark 开头,并接收 *testing.B 参数。
示例:测试字符串拼接性能
func BenchmarkStringConcat(b *testing.B) {for i := 0; i var s string
for j := 0; j s += "x"
}
}
}
b.N 表示测试循环的次数,由Go运行时自动调整,目标是让测试持续约1秒以上,从而获得稳定的性能数据。
2. 控制测试时间和迭代次数
默认情况下,Go会动态调整 b.N 来获取可靠的测量结果。你也可以手动控制测试时长:
-
go test -bench=.—— 运行所有基准测试 -
go test -bench=BenchmarkStringConcat -benchtime=5s—— 每个测试至少运行5秒 -
go test -bench=BenchmarkStringConcat -count=3—— 重复测试3次,用于观察波动
3. 内存分配测试与性能分析
使用 b.ReportAllocs() 可输出每次操作的内存分配次数和字节数。
b.ReportAllocs()
for i := 0; i _ = make([]byte, 1024)
}
}
输出示例:
BenchmarkWithAlloc-8 1000000 1000 ns/op 1024 B/op 1 allocs/op
其中:
1024 B/op 表示每次操作分配了1024字节内存,1 allocs/op 表示每次操作发生1次内存分配。
Pinokio
Pinokio是一款开源的AI浏览器,可以安装运行各种AI模型和应用
232
查看详情
4. 重置计时器与分离准备逻辑
如果测试前需要初始化大量数据,应避免将这部分时间计入性能统计。可使用 b.ResetTimer()、b.StartTimer() 和 b.StopTimer() 精确控制计时范围。
data := make([]int, 1e6)
for i := range data {
data[i] = i
}
b.ResetTimer() // 开始计时前完成初始化
for i := 0; i _ = sum(data)
}
}
也可以在循环中暂停和恢复计时,例如模拟I/O等待:
b.StopTimer()// 模拟清理或准备操作
b.StartTimer()
5. 子基准测试(Sub-Benchmarks)
当需要对比不同输入规模或实现方式时,可使用 b.Run() 创建子测试。
sizes := []int{10, 100, 1000}
for _, n := range sizes {
b.Run(fmt.Sprintf("Size-%d", n), func(b *testing.B) {
data := make([]int, n)
for i := 0; i _ = sum(data)
}
})
} }
运行后会分别输出每个子测试的结果,便于横向比较。
6. 避免编译器优化导致的误判
Go编译器可能优化掉“无副作用”的计算。为防止这种情况,应将结果赋值给 blackhole 变量或使用 runtime.ReadMemStats 强制保留。
推荐做法:
var result intfunc BenchmarkSum(b *testing.B) {
data := []int{1, 2, 3, 4, 5}
var r int
for i := 0; i r = sum(data)
}
result = r // 防止被优化掉
}
基本上就这些。合理使用 *testing.B 能帮你发现性能瓶颈,验证优化效果,是Go项目中不可或缺的工具。记得结合 -benchmem 和 pprof 做深入分析。不复杂但容易忽略细节。
以上就是如何在Golang中使用testing.B进行性能测试_Golang testing.B性能测试方法汇总的详细内容,更多请关注其它相关文章!
# go
# 性能测试
# 计时器
# 这部
# 相关文章
# 帮你
# 时长
# 如何在
# 全局变量
# 内存管理
# 性能瓶颈
# 工具
# 字节
# go语言
# golang
# 自定义
# 央企网站建设要点
# seo发掘易速达
# 西宁网站建设费用多少钱
# 战略关键词排名软件下载
# 武汉商城seo推广
# 西藏seo排名是什么
# 扬州关键词排名厂家
# 宁波生活用品营销推广
# 总结汇报网站优化建议
# 淄博seo工具
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
J*aScript中如何高效提取对象指定属性
QQ邮箱官方登录入口_QQ邮箱网页版快捷使用平台
Lar*el如何正确地在控制器和模型之间分配逻辑_Lar*el代码职责分离与架构建议
Bilibili动漫最新防封地址发布-Bilibili动漫2025年最稳正版入口推荐
漫蛙官网正版漫画入口 漫蛙2官方网页登录地址
Excel文件在线转换快速入口 Excel在线格式转换网站
深入理解J*a合成构造器:何时以及为何阻止其生成
期待已久:小米17 Ultra、小米首款NAS本月登场
限制HTML日期输入框的日期选择范围
12306怎么选座位选到安静区_12306选座安静区域选择策略
高德地图公交到站提醒失败如何解决 高德提醒权限设置
大麦的“候补”是什么意思 大麦候补购票规则【详解】
Win10快速启动功能利弊分析 Win10开启或关闭快速启动教程【技巧】
TikTok评论显示延迟如何处理 TikTok评论刷新优化方法
如何使用Node.js csv 包按条件移除含空字段的CSV记录
MongoDB聚合管道:正确匹配对象数组中_id的方法
Golang如何使用net/url解析URL_Golang URL解析与处理方法
如何使用CaptainHook和Composer管理Git钩子_在提交前自动运行代码检查的Composer配置
Golang如何通过reflect操作map_Golang reflect map操作与遍历技巧
Win10文件资源管理器“此电脑”分组怎么关 Win10恢复经典视图【技巧】
AO3官网镜像链接 Archive of Our Own同人文在线浏览
sublime怎么覆盖插件的默认快捷键_sublime快捷键优先级与设置
Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析
Tabulator表格中精确实现日期时间排序的指南
妖精动漫免费平台 妖精动漫官网资源观看网址
在FastAPI中利用lifespan与依赖注入高效管理Redis连接池
Descript怎样用AI剪辑自动去噪_Descript用AI剪辑自动去噪【自动降噪】
2025俄罗斯Yandex最新入口 官方网站地址及浏览器下载指南
J*aScript动态修改指定div内所有a标签样式指南
Golang如何实现简单的Web表单_Golang表单提交与验证处理方法
AO3同人作品网入口 AO3搜索引擎官网永久地址
Python异步编程实践:使用Binance API构建实时交易数据流
黑猫投诉统一入口官网 消费者权益保护投诉平台
win11专注助手在哪 Win11免打扰模式设置与自动化规则【指南】
理解J*aScript Promise的微任务队列与执行顺序
如何仅使用CSS更改登录界面背景图像图标的颜色
Golang如何实现微服务鉴权与权限控制_Golang微服务鉴权与权限管理实践
css链接悬停下划线样式如何自定义_使用::after结合content和transition
css滚动区域卡顿如何改善_css滚动问题用will-change优化渲染
uc浏览器网页版极速入口 uc网页浏览器网页版流畅体验
解决Django多数据库/多Schema环境下外键迁移问题
CSS Flexbox如何实现多行排列_flex-wrap wrap自动换行显示
J*aScript 字符串标签转换:使用正则表达式高效替换
Lar*el Excel导入时生成自定义递增ID的策略与实践
Go调试环境为何无法启动_Go调试器启动失败原因与解决策略
QQ邮箱登录首页官网地址2026 QQ邮箱官方网页入口
css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异
新三国志曹操传110级星符试炼夏侯渊极难攻略
微博网页版主页入口 微博官方网站免登录访问
Win11文件资源管理器卡顿怎么修 Win11重置资源管理器进程优化响应速度【修复方法】


2025-10-29
浏览次数:次
返回列表