Verstehen der hexadezimalen Darstellung der 64-Bit-Ganzzahl -1 in Go und C
In Go und C wird das %x-Format verwendet Gibt ganze Zahlen in hexadezimaler Schreibweise aus. Bei Anwendung auf die negative 64-Bit-Ganzzahl -1 entsteht jedoch eine Divergenz.
In Go behält %x den negativen Wert bei und zeigt „-1“ an, während C „ffffffffffffffff“ ausgibt. Diese Ungleichheit ergibt sich aus der strengen Typbehandlung von Go.
Um die hexadezimale Darstellung von -1 als vorzeichenlose Ganzzahl in Go auszugeben, ist eine explizite Konvertierung erforderlich. Durch die Konvertierung in uint wird sichergestellt, dass der Wert als vorzeichenloser Typ interpretiert wird:
fmt.Printf("%d %x %d %x", i, i, uint(i), uint(i))
Dies führt zu der Ausgabe:
-1 -1 4294967295 ffffffff
Der zweite Hexadezimalwert („ffffffffff“) stellt den dar 2er-Komplement von -1, wenn es als vorzeichenlose Ganzzahl behandelt wird.
Der Grund für dieses Verhalten besteht, wie von Rob Pike erklärt, darin, die Fähigkeit zu bewahren, negative Zahlen in einem kompakten Format zu drucken. Wenn das %x-Format Argumente immer als vorzeichenlos behandeln würde, gäbe es keine einfache Möglichkeit, negative Werte anzuzeigen.
Das obige ist der detaillierte Inhalt vonWarum gibt die Formatierung „%x' unterschiedliche Hexadezimaldarstellungen für -1 in Go und C aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!