Golang 性能基准测试(Benchmark)详解

Golang性能基准测试可以帮助开发人员比较不同的实现方式对性能的影响,以便优化程序,本文就来讲解一下如何使用Golang的性能基准测试功能。

Golang 性能基准测试

Golang 中的性能基准测试是使用标准库 testing 来实现的,编写性能测试代码是很容易的:

创建性能测试文件:在 Go 项目的源代码目录下创建一个新的文件(和被测代码文件在同一个包),以 _test.go 为后缀名。例如,要测试net包中 dial.go 中的方法,在 net 包中创建一个名字为 dial_test.go 文件,和单元测试文件是一样的。

导入 testing 包:在测试文件中导入testing包,以使用相关的的函数和工具。

编写测试函数:在测试文件中,编写一个以 Benchmark 为前缀的函数,后面跟上一个或多个字符或字符组合来标识测试用例的名称(一般使用被测的函数名称),参数必须是 b *testing.B。

编写测试代码:b.N是基准测试框架提供的,表示循环的次数,因为需要反复调用测试代码来评估性能。b.N 的值会以1, 2, 5, 10, 20, 50, …这样的规律递增下去直到运行时间大于1秒钟,由于程序判断运行时间稳定才会停止运行,所以千万不要在loop循环里面使用一个变化的值作为函数的参数。

以 json 格式校验工具https://github.com/luduoxin/json-validator-go 为例,validator包中的 scanner.go 文件中的关键函数 Valid 用于校验给定字符串是否 json 格式,对应的性能测试文件为 scanner_test.go,里面的测试函数为 BenchmarkValid,代码如下:

 
  1. package validator

  2.   import "testing"

  3.   func BenchmarkValid(b *testing.B) {

  4.   str := `{"foo":"bar"}`

  5.   b.ResetTimer()

  6.   for i := 0; i < b.N; i++ {

  7.   Valid([]byte(str))

  8.   }

运行性能测试用例

性能测试命令为 go test [参数],比如 go test -bench=. ,具体的命令参数及含义如下:

-bench regexp 性能测试,运行指定的测试函。

-bench . 运行所有的benchmark函数测试,指定名称则只执行具体测试方法而不是全部。

-benchmem 性能测试的时候显示测试函数的内存分配的统计信息。

-count n 运行测试和性能多少此,默认一次。

-run regexp 只运行特定的测试函数。

-timeout t 测试时间如果超过 t 则panic,默认10分钟。

-v 显示测试的详细信息。

启动命令行,切换到 json-validator-go 项目的 validator 文件夹下,运行全部性能测试用例:

  1. $ go test -bench=.

  2.   goos: darwin

  3.   goarch: amd64

  4.   pkg: github.com/luduoxin/json-validator-go/validator

  5.   cpu: Intel(R) Core(TM) i5-8259U CPU @ 2.30GHz

  6.   BenchmarkValid-8 13562608 86.55 ns/op

  7.   PASS

  8.   ok github.com/luduoxin/json-validator-go/validator 1.420s

上面输出的报告的倒数第三行信息的内容含义如下:

BenchmarkValid 是性能测试函数名称,-8 表示 GOMAXPROCS 的值为8,13562608 表示一共执行了13562608次,即b.N的值,86.55 ns/op 表示平均每次操作花费了 86.55 纳秒。

在一个测试方法里面也可以跑多个用例,使用更多的类型的数据分别看下对应的性能,代码如下:

  1.  package validator

  2.   import "testing"

  3.   func BenchmarkValid(b *testing.B) {

  4.   var validTests = []struct {

  5.   data string

  6.   ok bool

  7.   }{

  8.   {`foo`, false},

  9.   {`}{`, false},

  10.   {`{]`, false},

  11.   {`{}`, true},

  12.   {`[{}]`, true},

  13.   {`{"foo":"bar"}`, true},

  14.   {`{"foo":"bar","bar":{"baz":["qux"]}}`, true},

  15.   }

  16.   for _, v := range validTests {

  17.   b.Run("", func(b *testing.B) {

  18.   for i := 0; i < b.N; i++ {

  19.   Valid([]byte(v.data))

  20.   }

  21.   })

  22.   }

  23.   }

运行看下效果:

  1. $ go test -bench=.

  2.   goos: darwin

  3.   goarch: amd64

  4.   pkg: github.com/luduoxin/json-validator-go/validator

  5.   cpu: Intel(R) Core(TM) i5-8259U CPU @ 2.30GHz

  6.   BenchmarkValid/#00-8 4746290 249.8 ns/op

  7.   BenchmarkValid/#01-8 4841005 245.5 ns/op

  8.   BenchmarkValid/#02-8 4610671 257.0 ns/op

  9.   BenchmarkValid/#03-8 26957421 42.63 ns/op

  10.   BenchmarkValid/#04-8 29747263 41.88 ns/op

  11.   BenchmarkValid/#05-8 20895832 56.31 ns/op

  12.   BenchmarkValid/#06-8 14058906 83.17 ns/op

  13.   BenchmarkValid/#07-8 5518412 212.9 ns/op

  14.   PASS

  15.   ok github.com/luduoxin/json-validator-go/validator 10.891s

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

  • 28
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值