首页 > 后端开发 > Golang > 正文

Golang基准测试如何测量内存分配

P粉602998670
发布: 2025-10-11 20:52:01
原创
146人浏览过
Go语言基准测试通过b.ReportAllocs()可统计内存分配情况,输出包含每次操作的平均内存分配字节数(B/op)和分配次数(allocs/op),结合b.SetBytes()还能分析数据处理时的内存效率与吞吐关系。

golang基准测试如何测量内存分配

Go语言的基准测试(Benchmark)不仅能测量代码执行时间,还能统计内存分配情况。要了解一段代码在运行时分配了多少内存、分配了多少次,可以直接通过*testing.B提供的方法获取。

使用 b.ReportAllocs() 记录内存分配

在基准测试函数中调用 b.ReportAllocs(),即可开启对内存分配的追踪。Go运行时会自动记录每次基准循环中的堆内存分配总量和分配次数。

例如:

func BenchmarkExample(b *testing.B) {
    b.ReportAllocs()
    for i := 0; i < b.N; i++ {
        // 被测代码
        _ = make([]int, 100)
    }
}

运行这个基准测试时,输出结果会包含三部分:
- 基准耗时(ns/op)
- 内存分配字节数(B/op)
- 分配次数(allocs/op)

理解输出中的内存指标

执行 go test -bench=. 后,你会看到类似这样的输出:

立即学习go语言免费学习笔记(深入)”;

BenchmarkExample-8 10000000 120 ns/op 400 B/op 1 allocs/op

其中:

AGI-Eval评测社区
AGI-Eval评测社区

AI大模型评测社区

AGI-Eval评测社区 63
查看详情 AGI-Eval评测社区
  • 400 B/op:表示每次操作平均分配了400字节内存
  • 1 allocs/op:表示每次操作发生了1次内存分配

这些数据来自Go运行时的采样统计,仅反映堆上分配的情况,上分配不会计入。

结合 b.SetBytes() 测量吞吐相关的内存效率

如果你的基准测试处理的是数据流或缓冲区操作,可以配合 b.SetBytes() 来展示每秒处理的数据量与内存开销的关系。

比如测试复制1KB数据:

func BenchmarkCopy(b *testing.B) {
    b.ReportAllocs()
    data := make([]byte, 1024)
    for i := 0; i < b.N; i++ {
        copied := make([]byte, len(data))
        copy(copied, data)
    }
    b.SetBytes(1024)
}

此时输出会额外体现带宽信息,如 MB/s,并将内存分配归一化到每字节操作的成本,帮助你判断性能瓶颈是否与内存有关。

基本上就这些。只要加上 b.ReportAllocs(),就能清楚看到你的函数在真实场景下是否频繁触发GC或产生过多小对象。这对优化性能敏感路径非常有用。

以上就是Golang基准测试如何测量内存分配的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号