Memahami Limpahan Integer dalam Pemalar Go
Pengaturcaraan Dalam Go, cubaan untuk memasukkan nilai yang terlalu besar ke dalam pemalar integer boleh membawa kepada penyusunan ralat. Pertimbangkan coretan kod berikut:
<code class="go">userid := 12345 did := (userid & ^(0xFFFF << 48))</code>
Setelah menyusun kod ini, anda mungkin menghadapi ralat berikut:
./xxxx.go:511: constant -18446462598732840961 overflows int
Ralat ini berpunca daripada sifat ungkapan malar yang tidak ditaip dalam Go.
Pemalar Tidak Ditaip dan Limpahan Integer
Dalam kod yang diberikan, pemalar ^(0xFFFF << 48) mempunyai nilai yang tidak ditaip, bermakna ia boleh menyimpan besar sewenang-wenangnya integer. Walau bagaimanapun, apabila cuba melakukan operasi AND bitwise dengan id pengguna integer yang ditaip, pengkompil cuba menghantar pemalar yang tidak ditaip kepada jenis int. Nilai yang terhasil, -18446462598732840961, melebihi nilai maksimum yang boleh diwakili untuk int, yang membawa kepada ralat limpahan.
Menyelesaikan Isu Limpahan
Untuk mengelakkan ralat limpahan ini, adalah penting untuk menaip pemalar yang tidak ditaip secara eksplisit. Dalam kes ini, anda boleh menggunakan kod berikut sebaliknya:
<code class="go">userid := 12345 did := (userid & (uint64(1<<48) - 1))</code>
Dengan menghantar pemalar secara eksplisit ke uint64 menggunakan uint64(1<<48) - 1, anda memastikan kedua-dua operan dalam operasi bitwise AND mempunyai jenis yang sama, menghapuskan isu limpahan.
Atas ialah kandungan terperinci Mengapa Pergi Melemparkan Ralat Limpahan Apabila Menggunakan Pemalar Tidak Ditaip dalam Operasi Bitwise?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!