Rumah > pembangunan bahagian belakang > Golang > Mengapakah mengukur masa pelaksanaan fungsi dengan `tunda` dalam Go kadangkala mengembalikan sifar?

Mengapakah mengukur masa pelaksanaan fungsi dengan `tunda` dalam Go kadangkala mengembalikan sifar?

Patricia Arquette
Lepaskan: 2024-11-23 04:10:15
asal
842 orang telah melayarinya

Why does measuring function execution time with `defer` in Go sometimes return zero?

Cara Mengukur Masa Pelaksanaan Fungsi dalam Go

Apabila menjejak prestasi fungsi Go, adalah perkara biasa untuk menggunakan pernyataan tangguh untuk menangguhkan perlaksanaan fungsi sehingga fungsi sekeliling kembali. Walau bagaimanapun, dalam kes tertentu, menangguhkan pelaksanaan fungsi untuk mencetak masa pelaksanaannya boleh mengakibatkan output nilai sifar yang tidak dijangka.

Pertimbangkan kod berikut:

func sum() {
    start := time.Now()

    //expecting to print non zero value but always gets 0
    defer fmt.Println(time.Now().Sub(start))

    sum := 0
    for i := 1; i < 101; i++ {
        sum += i
    }
    time.Sleep(1 * time.Second)
    fmt.Println(sum)
}
Salin selepas log masuk

Dalam contoh ini , pernyataan tangguh cuba mencetak masa yang telah berlalu sejak fungsi itu pada mulanya dipanggil. Walau bagaimanapun, kerana hujah kepada fungsi tertunda dinilai pada titik fungsi itu ditangguhkan, panggilan masa.Now() dibuat serta-merta apabila mula ditetapkan, menghasilkan masa mula yang tidak menggambarkan masa sebenar yang diambil untuk melaksanakan fungsi.

Untuk menangani isu ini, kod boleh diubah suai seperti berikut:

defer func() { fmt.Println(time.Now().Sub(start)) }()
Salin selepas log masuk

Dengan membalut Panggilan fmt.Println dalam fungsi tanpa nama, argumen kepada fungsi tertunda dinilai apabila fungsi itu dilaksanakan, memastikan masa mula ditangkap dengan betul.

Selain itu, menggunakan fungsi boleh guna semula untuk merangkum logik pemasaan boleh memudahkan lagi kod:

func timeFunction(f func()) {
    start := time.Now()
    f()
    fmt.Println(time.Now().Sub(start))
}
Salin selepas log masuk

Fungsi ini kemudiannya boleh digunakan sebagai berikut:

timeFunction(func() {
    sum := 0
    for i := 1; i < 101; i++ {
        sum += i
    }
    time.Sleep(1 * time.Second)
    fmt.Println(sum)
})
Salin selepas log masuk

Dengan memahami cara fungsi tertunda berfungsi dalam Go, pembangun boleh mengukur masa pelaksanaan fungsi dengan berkesan dan mengoptimumkan prestasinya.

Atas ialah kandungan terperinci Mengapakah mengukur masa pelaksanaan fungsi dengan `tunda` dalam Go kadangkala mengembalikan sifar?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan