Benchmark: 性能测试
ns/op: 纳秒/每个操作,前面数值越小越快
建立一个包,创建一个test文件如,文件名为lib_test.go
package lib
import (
"testing"
"fmt"
)
const (
str = "hello gohpers!"
sep = ","
)
func BenchmarkFmt(b *testing.B) {
for i := 0; i < b.N ; i++ {
_ = fmt.Sprintf("%s%s%s%s%s", str, sep, str, sep, str)
}
}
func BenchmarkPlus(b *testing.B) {
for i:=0; i < b.N; i++ {
_ = str + sep + str + sep + str
}
}
然后运行 go test -bench=.
后面这个参数"." 不能加引号
结果
// Benchmark 名字 - CPU 循环次数 平均每次执行时间
BenchmarkFmt-4 3000000 554 ns/op
BenchmarkPlus-4 2000000000 0.36 ns/op
结论: 0.36 更快一点
后续继续补充