Penilaian Litar Pendek dalam Go: Susunan Ungkapan Boolean
In Go, seperti banyak bahasa pengaturcaraan lain, penilaian litar pintas dilaksanakan dalam keadaan bersyarat ungkapan. Ini bermakna ungkapan boolean bersarang dinilai dalam susunan tertentu, mengoptimumkan prestasi dalam kes tertentu.
Pertimbangkan kod berikut:
if error != nil || someFunc() || otherFunc() { return }
Jika ralat dalam ungkapan di atas bukan sifar, Go akan segera kembali tanpa memanggil someFunc() atau otherFunc(). Ini kerana || ialah pengendali litar pintas. Jika subungkapan pertama (ralat) dinilai kepada benar, hasil ungkapan keseluruhan diketahui benar tanpa mengira hasil subungkapan berikutnya.
Dalam contoh lain:
if !isValidQueryParams(&queries) || r == nil || len(queries) == 0 { return }
Oleh kerana penilaian litar pintas berkuat kuasa, jika isValidQueryParams() mengembalikan palsu, Go akan segera kembali tanpa menyemak sama ada r adalah sifar atau jika senarai pertanyaan adalah kosong. Pendekatan ini membantu mengurangkan pengiraan yang tidak perlu.
Oleh itu, apabila mengoptimumkan prestasi dalam senario sedemikian, anda harus mempertimbangkan potensi kos bagi setiap panggilan fungsi dan meletakkannya dalam susunan yang memanfaatkan penilaian litar pintas. Go akan menilai ungkapan dari kiri ke kanan dan sebaik sahaja hasil keseluruhan (benar atau salah) ditentukan, ungkapan yang selebihnya tidak akan dinilai.
Atas ialah kandungan terperinci Bagaimanakah Penilaian Litar Pendek Mengoptimumkan Ungkapan Bersyarat dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!