在Go语言中,提供了测试函数性能(CPU和Memory)的测试方法,基准测试。
基准测试主要用来测试CPU和内存的效率问题,来评估被测代码的性能。测试人员可以根据这些性能指标的反馈,来优化我们的代码,进而提高性能问题。
本篇文章主要来介绍,基准测试的使用方法和性能指标的分析。
1. 使用规则如下所示:
1.基准测试的代码文件必须以_test.go结尾。 2.基准测试的函数必须以Benchmark开头。 3.基准测试函数必须接受一个指向testing.B类型的指针作为唯一参数。 4.在测试执行之前,需要调用b.ResetTimer(重置计时器)来重置时间,以便过滤掉测试之前代码所消耗的时间。 5.测试代码需要写在for循环中,并且循环中的最大值是b.N。
2.用例介绍:
文件结构为:benchmark.go, benchmark_test.go,测试用例的写法,参看右边的测试代码。
3.运行基准测试:
$ go test -bench=. -benchtime=5s -benchmem -run=none
参数介绍:
-bench=. :表示的是运行所有的基准测试,. 表示全部。 -benchtime=5s:表示的是运行时间为5s,默认的时间是1s。 -benchmem:表示显示memory的指标。 -run=none:表示过滤掉单元测试,不去跑UT的cases。
输出的结果内容分析:
goos: darwin:表示的是操作系统是darwin。 goarch: amd64:表示目标平台的体系架构是amd64。 BenchmarkHandleWithType-4:BenchmarkHandleWithType表示运行的函数名称;4表示的是,运行时对应的GOMAXPROCS的值。 10000000000:表示的是b.N的在5s内的值。 0.28 ns/op:表示执行一次这个函数,消耗的时间是0.28ns。 0 B/op:表示每次执行操作,分配0B的内存。 0 allocs/op:表示执行一次这个函数,分配内存的次数为1次。
参考文章: Golang在Mac、Linux、Windows下如何交叉编译:https://laucyun.com/5d140bb00295137f0caa0ade248390fb.html
Go学习笔记(三) | 怎么写Go基准测试(性能测试):https://razeencheng.com/post/go-how-to-write-benchmark.html
Go语言实战笔记(二十二)| Go 基准测试:https://www.flysnow.org/2017/05/21/go-in-action-go-benchmark-test.html
1. Go 性能调优之 —— 基准测试:https://segmentfault.com/a/1190000016354758