Memahami Perbezaan Pencetakan Heksadesimal antara Go dan C: Kes -1
Dalam Go, format %x untuk mencetak integer mewakili nilai dalam tatatanda heksadesimal. Ini berbeza daripada %x C, yang mencetak perwakilan memori bagi integer yang ditandatangani. Perbezaan ini membawa kepada hasil yang tidak dijangka apabila mencetak integer negatif -1.
In Go:
var x uint64 = 1 << 64 - 1 fmt.Printf("%x\n", x)
Output:
ffffffffffffffffffff
Di sini, %x mencetak dengan betul perwakilan heksadesimal bagi nilai tidak bertanda 1<<64 - 1.
Dalam C:
#include <stdio.h> int main() { uint64_t x = 1LL << 64 - 1; printf("%x\n", (long long)x); }
Output:
-1
Dalam C, %x mencetak nilai integer yang ditandatangani -1, nampaknya menghasilkan nombor heksadesimal negatif dengan '-' di hadapan. Walau bagaimanapun, ini tidak berlaku; tanda '-' menunjukkan bahawa integer adalah negatif, dan nilai heksadesimal ffff...ff ialah perwakilan pelengkap 2 bagi -1.
Go menguatkuasakan penaipan yang ketat, memerlukan penukaran jenis eksplisit untuk menganggap integer bertanda sebagai tidak ditandatangani. Untuk mencetak -1 sebagai nilai yang tidak ditandatangani dalam Go:
i := -1 // type int fmt.Printf("%x", uint(i))
Output:
ffffffff
Pendekatan ini menukarkan integer yang ditandatangani kepada rakan sejawatannya yang tidak ditandatangani, menghasilkan perwakilan heksadesimal yang betul .
Gelagat lalai Pergi ke mencetak integer negatif sebagai nilai yang ditandatangani membolehkan perwakilan ringkas, tetapi ia boleh membawa kepada keputusan yang tidak dijangka dalam konteks perenambelasan. Memahami perbezaan ini adalah penting untuk penulisan kod yang berkesan dalam Go.
Atas ialah kandungan terperinci Mengapakah pencetakan -1 sebagai perenambelasan dalam Go dan C menghasilkan hasil yang berbeza?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!