golang基准测试可以提供自定义输出吗?

golang基准测试可以提供自定义输出吗?,第1张

概述我使用不同的列表大小对代码进行基准测试(大小为S的列表)Go基准测试显示ns / op但我想要的是(ns / op)/ S. 换句话说,go test -bench =的输出.是: BenchmarkMy10-4 100000000 15.7 ns/opBenchmarkMy20-4 50000000 33.8 ns/op 我使用不同的列表大小对代码进行基准测试(大小为S的列表)Go基准测试显示ns / op但我想要的是(ns / op)/ S.

换句话说,go test -bench =的输出.是:

BenchmarkMy10-4         100000000           15.7 ns/opBenchmarkMy20-4         50000000            33.8 ns/opBenchmarkMy30-4         30000000            43.8 ns/opBenchmarkMy40-4         30000000            49.3 ns/opBenchmarkMy50-4         30000000            56.6 ns/opBenchmarkMy1000-4        2000000           686 ns/opBenchmarkMy10000-4        200000          6685 ns/opBenchmarkMy100000-4        20000         65425 ns/op

“My10”中的“10”表示10个项目的列表(S = 10).

虽然知道不同列表大小的ns / op很有用,但我还想知道ns / op / S(列表中每个项目的时间).

现在我将结果粘贴到电子表格中并在那里进行数学运算.但是,我希望“go test”为我输出这些信息.

我的main_test.go文件如下所示:

import "testing"var result intfunc benchmarkMy(i int,b *testing.B) {  var r int  myList := MakeList(i)  b.resetTimer()  for n := 0; n < b.N; n++ {    r = My(myList)  }  result = r}func BenchmarkMy10(b *testing.B)         { benchmarkMy(10,b) }func BenchmarkMy20(b *testing.B)         { benchmarkMy(20,b) }func BenchmarkMy30(b *testing.B)         { benchmarkMy(30,b) }func BenchmarkMy40(b *testing.B)         { benchmarkMy(40,b) }func BenchmarkMy50(b *testing.B)         { benchmarkMy(50,b) }func BenchmarkMy1000(b *testing.B)       { benchmarkMy(1000,b) }func BenchmarkMy10000(b *testing.B)      { benchmarkMy(10000,b) }func BenchmarkMy100000(b *testing.B)     { benchmarkMy(100000,b) }

看起来test.BenchmarkResult结构有我需要的信息,但我不知道如何使用这个结构.

解决方法 您可以使用包测试中的 Benchmark函数编写自定义基准.并获得你提到的BenchmarkResult实例.

package mainimport (    "fmt"    "testing")func benchmarkMy(i int) {    fn := func(b *testing.B) {         // Code you want benchmarked    }    r := testing.Benchmark(fn)    fmt.Printf("%d ns/op\n",int(r.T)/r.N)    fmt.Printf("%d ns/op/i\n",int(r.T)/r.N/i)}func main() {    benchmarkMy(10)}

你必须把它放在一个不同的包中并运行go run而不是go test.

查看playground中的示例.

总结

以上是内存溢出为你收集整理的golang基准测试可以提供自定义输出吗?全部内容,希望文章能够帮你解决golang基准测试可以提供自定义输出吗?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1265600.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存