Konstantenüberläufe in Go verstehen
Die Programmiersprache Go bietet ein umfassendes Typensystem, einschließlich des Konzepts von Konstanten. Bei der Arbeit mit Konstanten ist es jedoch wichtig, sich möglicher Überläufe bewusst zu sein. Ein solcher Fall beinhaltet die Verwendung einer untypisierten Konstante, um bitweise Operationen an einer typisierten Variablen auszuführen.
Problembeschreibung
Bedenken Sie den folgenden Codeausschnitt:
<code class="go">userid := 12345 did := (userid & ^(0xFFFF << 48))</code>
Beim Versuch, diesen Code zu kompilieren, wird möglicherweise die Fehlermeldung angezeigt:
./xxxx.go:511: constant -18446462598732840961 overflows int
Erklärung
Der Ausdruck ^(0xFFFF << 48) stellt dar eine untypisierte Konstante. In Go können untypisierte Konstanten beliebig große Werte annehmen. In diesem Fall ist das Ergebnis der Negationsoperation -0xffff000000000001, was zu groß ist, um in ein int zu passen.
Wenn Sie das Ergebnis der bitweisen Operation der Variablen did zuweisen, die vom Typ int ist, Der Compiler versucht, die nicht typisierte Konstante in ein int zu konvertieren, was zu einem Überlauffehler führt.
Lösung
Um dieses Problem zu beheben, können Sie eine passende alternative Konstante verwenden innerhalb des int-Typs. Beispielsweise können Sie den problematischen Ausdruck durch 1<<48 - 1 ersetzen. Diese Berechnung ergibt die Konstante 0x0000ffffffffffff, die mit int64 auf 64-Bit-Systemen kompatibel ist.
Zusätzlicher Tipp
Wenn Sie Portabilität anstreben, wird empfohlen, in Ihrem Code int64 anstelle von int zu verwenden. Dadurch wird sichergestellt, dass der genannte Code auch auf Systemen korrekt funktioniert, auf denen int 32-Bit ist.
Das obige ist der detaillierte Inhalt vonWarum löst mein Go-Code einen Konstantenüberlauffehler aus, wenn er bitweise Operationen mit untypisierten Konstanten verwendet?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!