b.N
次, 而且每次执行都会如此。在执行过程中会根据实际 case 的执行时间是否稳定会增加 b.N
的次数以达到稳态(找到一个稳态的执行时间)。
go test -bench=BenchmarkAll -v
func TestMain(m *testing.M) {
fmt.Println("test main entry")
m.Run()
}
func print1to20() int {
res := 0
for i := 1; i <= 20; i++ {
res += i
}
return res
}
func BenchmarkAll(b *testing.B) {
for n := 0; n < b.N; n++ {
print1to20()
}
}
func TestMain(m *testing.M) {
fmt.Println("test main entry")
m.Run()
}
// 稳态
func aaa1(n int) int {
return n
}
// 非稳态
func aaa2(n int) int {
for n > 0 {
n--
}
return n
}
func BenchmarkAll(b *testing.B) {
for n := 0; n < b.N; n++ {
// aaa1(n)
aaa2(n)
}
}
$ go test -bench=. -cpu=1,2,4,8,12,16 -run=none
ab 是由 C 语言写的 benchmark tool, 非常经典, 是 Apache httpd 的一个工具,可以通过 httpd 下载获取到。
https://httpd.apache.org/docs/current/platform/windows.html#down