Go   发布时间:2022-04-09  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了golang基准测试可以提供自定义输出吗?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_675_2@
我使用不同的列表大小对代码进行基准测试(大小为S的列表)Go基准测试显示ns / op但我想要的是(ns / op)/ s.

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

BenchmarkMy10-4         100000000           15.7 ns/op
BenchmarkMy20-4         50000000            33.8 ns/op
BenchmarkMy30-4         30000000            43.8 ns/op
BenchmarkMy40-4         30000000            49.3 ns/op
BenchmarkMy50-4         30000000            56.6 ns/op
BenchmarkMy1000-4        2000000           686 ns/op
BenchmarkMy10000-4        200000          6685 ns/op
BenchmarkMy100000-4        20000         65425 ns/op

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

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

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

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

import "tesTing"

var result int

func 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结构有我需要的信息,但我不知道如何使用这个结构.

@H_675_2@

解决方法

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

package main

import (
    "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中的示例.

@H_675_2@ @H_675_2@
@H_675_2@
@H_675_2@

大佬总结

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

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

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。