Mengesan Limpahan Integer Ditandatangani dalam Go
Limpahan integer ialah isu penting untuk dipertimbangkan apabila bekerja dengan operasi berangka dalam mana-mana bahasa pengaturcaraan, termasuk Go . Dalam konteks ini, memahami cara mengesan limpahan integer dengan cekap adalah penting untuk memastikan integriti data dan mengelakkan tingkah laku yang tidak dijangka.
Untuk integer bertanda 32-bit, Limpahan boleh berlaku apabila hasil operasi aritmetik melebihi maksimum atau minimum nilai yang boleh diwakili untuk jenis itu. Salah tanggapan yang lazim ialah integer secara automatik "bergulung" apabila mereka mencapai hadnya, tetapi ini tidak berlaku dalam Go. Sebaliknya, limpahan integer menghasilkan gelagat yang tidak ditentukan.
Untuk menggambarkan masalah ini, pertimbangkan contoh berikut:
a, b := 2147483647, 2147483647 c := a + b
Jika kita melakukan penambahan ini secara naif, hasilnya tidak akan menjadi nilai yang dijangkakan 4294967294, tetapi sebaliknya 0. Ini kerana jumlah melimpah nilai maksimum yang boleh dipegang oleh integer bertanda 32-bit. Oleh itu, adalah penting untuk mengesan limpahan sedemikian secara eksplisit.
Satu cara yang cekap untuk mengesan limpahan integer 32-bit untuk penambahan ialah dengan menyemak tanda-tanda operan dan hasilnya. Sebagai contoh, fungsi berikut melakukan semakan ini untuk penambahan:
func Add32(left, right int32) (int32, error) { if right > 0 { if left > math.MaxInt32-right { return 0, ErrOverflow } } else { if left < math.MinInt32-right { return 0, ErrOverflow } } return left + right, nil }
Dengan melaksanakan jenis semakan ini untuk setiap operasi aritmetik, anda boleh mengesan dan mengendalikan limpahan integer dengan berkesan dalam kod Go anda, memastikan integriti pengiraan dan keteguhan aplikasi anda.
Atas ialah kandungan terperinci Bagaimana untuk Mengesan Limpahan Integer Bertanda dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!