登录
首页 >  Golang >  Go问答

运行 Go 基准测试的正确输出

来源:stackoverflow

时间:2024-04-08 23:33:37 435浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《运行 Go 基准测试的正确输出》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!

问题内容

当我在此存储库上运行基准测试时(只是任何 go 项目的占位符),使用:

go test -run="^$" -bench="^benchmarklessorrevoke1000$"  ./...

我得到的输出是这样的,基准测试结果如下:

BenchmarkLessorRevoke1000-8      1033351          1141 ns/op

还有一大堆其他测试输出。如何让它只显示基准测试而不显示测试输出?


解决方案


您可以向 go test 工具的 -run 参数提供一个虚拟名称,并且假设您没有任何与该名称匹配的测试,则只应运行基准测试。

您使用 "^$" 涵盖了这一点,所以一切都很好,您还有一个模式可以与 "^benchmarklessorrevoke1000$" 匹配基准。

问题是您正在使用 ./... 在整个包和/或子目录中运行 go test。

您应该指定要在每个包的基础上运行的基准测试。

go test -run="$^" -bench="^BenchmarkLessorRevoke1000$" .
go test -run="$^" -bench="^BenchmarkLessorRevoke1000$" ./pkg1/
go test -run="$^" -bench="^BenchmarkLessorRevoke1000$" ./pkg2/

Also be mindful, if you do want to run benchmarks in mass you should do so on a per-package basis.

对多个包运行基准测试将同时执行它们,从而扭曲您的结果。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>