Rumah > Artikel > pembangunan bahagian belakang > Penanda aras prestasi dalam ujian fungsi Golang
Penanda aras prestasi dalam Go mengukur kecekapan fungsi dan dilaksanakan dengan menulis kod penanda aras dalam fungsi bermula dengan Penanda Aras. Jenis testing.B menyediakan sifat ResetTimer(), StopTimer(), dan N untuk mengawal tingkah laku penanda aras. Sebagai contoh, penanda aras bagi fungsi yang mengira nombor Fibonacci menunjukkan bahawa melaksanakan Fib(30) mengambil masa kira-kira 2,767,425 nanosaat. Optimumkan kod penanda aras untuk mengelakkan overhed dan jalankan beberapa kali untuk hasil yang tepat.
Tanda aras prestasi dalam ujian fungsi Go
Tanda aras prestasi ialah alat penting untuk mengukur kecekapan fungsi. Dalam Go, pakej testing
menyediakan kefungsian untuk menanda aras masa pelaksanaan fungsi. testing
包提供了针对函数执行时间的基准测试功能。
编写性能基准测试
编写一个性能基准测试需要创建一个以 Benchmark
开头的函数,后面跟上要测试的函数名:
func BenchmarkFib(b *testing.B) { // 基准测试代码 }
使用 testing.B
testing.B
类型提供以下方法来控制基准测试:
ResetTimer()
: 重置计时器。StopTimer()
: 停止计时器并记录时间。N
: 执行基准测试的次数。实战案例
让我们对一个计算斐波那契数的函数进行基准测试:
func Fib(n int) int { if n <= 1 { return n } return Fib(n-1) + Fib(n-2) } func BenchmarkFib(b *testing.B) { for i := 0; i < b.N; i++ { Fib(30) } }
在终端中运行测试:
go test -bench=.
输出将如下所示:
BenchmarkFib 2767425 ns/op
这意味着用 30 作为参数执行 Fib
函数的基准测试需要大约 2,767,425 纳秒(2767 毫秒)。
提示
-benchmem
testing.B
menyediakan kaedah berikut untuk mengawal penanda aras: 🎜ResetTimer()
: Tetapkan semula pemasa. 🎜🎜-benchmem
untuk mengukur peruntukan memori penanda aras. 🎜🎜Optimumkan kod penanda aras untuk mengelakkan overhed seperti mencipta pembolehubah yang tidak perlu. 🎜🎜Jalankan penanda aras beberapa kali untuk hasil yang lebih tepat. 🎜🎜Atas ialah kandungan terperinci Penanda aras prestasi dalam ujian fungsi Golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!