Heim >Backend-Entwicklung >Golang >Wie kann ich Int64 in Go sicher in Int konvertieren?

Wie kann ich Int64 in Go sicher in Int konvertieren?

Barbara Streisand
Barbara StreisandOriginal
2024-11-15 07:07:02619Durchsuche

How to Safely Convert Int64 to Int in Go?

Int64 in Int in Go konvertieren: Eine Anleitung

Typkonvertierung ist eine häufige Aufgabe in der Programmierung und in Go ist die Konvertierung unkompliziert zwischen zwei Ganzzahltypen. Das Verständnis der Unterschiede zwischen int und int64 ist entscheidend für genaue und effiziente Konvertierungen.

Die Herausforderung

Bei der Arbeit mit int64 (64-Bit-Ganzzahl) und int (32-Bit-Ganzzahl) Bit-Ganzzahl) in Go verwenden, müssen Entwickler möglicherweise die Werte dieser beiden Typen vergleichen. Die Konvertierung von int64 in int kann jedoch schwierig sein, da ein direkter Vergleich aufgrund eines Über- oder Unterlaufs zu unerwarteten Ergebnissen führen kann.

Ein häufiger Fehler besteht beispielsweise darin, einen int64-Wert direkt in int umzuwandeln, wie in der Abbildung gezeigt bereitgestellter Codeausschnitt:

for a := 2; a < maxInt; a++ {
    if isPrime(a) {
        if base.N % a == 0 {
            base.Result = a
        }
    }
}

Hier ist maxInt ein int64-Wert und die Schleifenbedingung (a < maxInt) versucht, einen int32 (a) mit einem int64 zu vergleichen. Dies kann zu falschen Ergebnissen führen.

Die Lösung

Um int64-Werte genau mit int in Go zu vergleichen, besteht der richtige Ansatz darin, den Typ int in int64 zu konvertieren. Dadurch wird sichergestellt, dass beide Werte vom gleichen Typ sind, wodurch das Risiko eines Über- oder Unterlaufs ausgeschlossen wird:

for a := 2; a < int64(maxInt); a++ {
    if isPrime(a) {
        if base.N % a == 0 {
            base.Result = a
        }
    }
}

Durch die Umwandlung von a in int64 vergleicht die Schleifenbedingung einen int64-Wert korrekt mit einem anderen int64-Wert und gewährleistet so einen ordnungsgemäßen Vergleich .

Zusätzliche Hinweise

Bei der Durchführung dieser Typkonvertierung ist es wichtig, die Möglichkeit eines Über- oder Unterlaufs zu berücksichtigen. Wenn der konvertierte Wert für den Zieltyp zu groß ist, kann es zu einem Überlauf kommen, der zu einem falschen Wert führt. Wenn umgekehrt der konvertierte Wert zu klein ist, kann es zu einem Unterlauf kommen, der den Wert auf eine untere Grenze kürzen kann.

Das obige ist der detaillierte Inhalt vonWie kann ich Int64 in Go sicher in Int konvertieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn