Fungsi Pemasa dan Pengiraan Masa Jalan dalam Go
Dalam Go, anda boleh menggunakan pakej masa untuk mengukur masa jalan dengan tepat bagi mana-mana fungsi dan mendapatkan semula nilai dalam milisaat. Satu pendekatan mudah melibatkan penggunaan ciri tangguh.
Dalam Go versi 1.x dan lebih awal, anda boleh mentakrifkan fungsi berikut:
func trace(s string) (string, time.Time) { log.Println("START:", s) return s, time.Now() } func un(s string, startTime time.Time) { endTime := time.Now() log.Println(" END:", s, "ElapsedTime in seconds:", endTime.Sub(startTime)) }
Dalam kod anda, anda kemudian boleh memanggil fungsi ini seperti berikut:
func someFunction() { defer un(trace("SOME_ARBITRARY_STRING_SO_YOU_CAN_KEEP_TRACK")) //do a bunch of stuff here... }
Dengan memanfaatkan pernyataan tangguh, fungsi surih() digunakan pada permulaan someFunction(), manakala fungsi un() ditangguhkan untuk dilaksanakan hanya selepas selesai someFunction (). Pendekatan ini menyediakan pengelogan masa jalan yang tepat sambil mengekalkan kesederhanaan kod.
Perhatikan bahawa contoh kod yang disediakan menggunakan penyataan pengelogan, yang mungkin menjejaskan sedikit ketepatan pengukuran masa jalan. Jika ketepatan yang lebih tinggi adalah penting, pertimbangkan untuk mencuba teknik alternatif yang meminimumkan overhed pembalakan.
Atas ialah kandungan terperinci Bagaimanakah Anda Boleh Mengukur Masa Jalanan Fungsi dalam Go Menggunakan Kata Kunci `defer`?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!