Rumah > Artikel > pembangunan bahagian belakang > Bagaimana untuk Menukar Go []bait kepada Nombor Integer Ditandatangani Kecil/Big-Endian atau Titik Terapung?
Bagaimana untuk Menukar Go []bait kepada Integer atau Terapung Bertanda Little/Big-Endian?
Apabila berurusan dengan data binari, ia adalah penting untuk memahami konsep endian, yang merujuk kepada cara nilai berangka berbilang bait disimpan dalam ingatan. Pakej binari Go menyediakan fungsi yang mudah untuk menukar antara jenis integer tidak bertanda big-endian dan little-endian seperti Uint16 dan Uint32. Walau bagaimanapun, ia tidak mempunyai sokongan langsung untuk integer yang ditandatangani dan nombor titik terapung.
Kunci untuk mengatasi had ini adalah dengan mendekati tugas dalam dua langkah:
Menukar kepada Integer Bertandatangan
Untuk mentafsir uint16 sebagai int16 yang ditandatangani, sebagai contoh, hanya gunakan penukaran jenis, kerana ia berkongsi reka letak memori yang sama:
<code class="go">a := binary.LittleEndian.Uint16(sampleA) a2 := int16(a)</code>
Prinsip yang sama digunakan untuk jenis integer bertanda yang lebih besar seperti int64.
Alternatif Menggunakan binari.Read() dan Write()
Fungsi binari.Baca dan Tulis Go boleh digunakan untuk melaksanakan penukaran ini dengan lebih cekap dengan mengakses perwakilan memori asas secara terus. Lihat contoh di bawah:<code class="go">a := binary.LittleEndian.Uint64(sampleA) a2 := math.Float64frombits(a) // To convert back to unsigned integer: a3 := math.Float64bits(a2)</code>
Atas ialah kandungan terperinci Bagaimana untuk Menukar Go []bait kepada Nombor Integer Ditandatangani Kecil/Big-Endian atau Titik Terapung?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!