Benchmark的写法
- benchmark函数一般以Benchmark开头,类似于BenchmarkXxx的格式命名,传入的参数是
b *testing.B
- benchmark的case一般会跑b.N次,而且每次执行都会如此
关于b.N这个东西,为了让程序达到稳态,在benchmark跑的过程中N是会一直变化的,所以一定要让程序稳态进行,如果出现了非稳态的状况,它就会一直跑不完。所以要保证你的benchmark在一定时间内达到稳态,如果这段不明白,看下面的例子。
- 在执行的过程中会根据实际case的执行时间是否稳定会增加b.N的次数以达到稳态
- benchmark 如果在有TestMain的情况下也会受到TestMain的限制,即如果有
TestMain(m *testing.M)
函数且其中没有m.Run()的话,同样不会执行写的benchmark函数 - 跑benchmark时,命令行输入
go test -bench=.
,其中.
表示test_name_regex,上例表示测试全部的压力测试函数 - go test 命令 带了 -bench参数之后,就只会跑BenchmarkXxx的函数,普通的单元测试函数TestXxx之类的不会跑
benchmark 非稳态:
结果:
因为benchmark中的loop每次传的参都不一样,所以aaa这个函数每次的执行时间都会随着n的增加而延长,而benchmark为了找到一个稳态的执行时间,会把b.N不停地增大,所以导致loop不中断。
benchmark 稳态:
结果: