Heim > Backend-Entwicklung > Golang > Wie kann ich Byte-Arrays in Go in vorzeichenbehaftete Ganzzahlen und Gleitkommazahlen konvertieren?

Wie kann ich Byte-Arrays in Go in vorzeichenbehaftete Ganzzahlen und Gleitkommazahlen konvertieren?

Patricia Arquette
Freigeben: 2024-10-29 07:53:30
Original
925 Leute haben es durchsucht

How can I convert byte arrays to signed integers and floats in Go?

Konvertieren von Byte-Arrays in vorzeichenbehaftete Ganzzahlen und Gleitkommazahlen in Go

In Go bietet das Binärpaket Funktionen zum Konvertieren von vorzeichenlosen Ganzzahlen aus []Byte Arrays wie „binary.LittleEndian.Uint16()“ und „binary.BigEndian.Uint32()“. Es gibt jedoch keine direkten Äquivalente für vorzeichenbehaftete Ganzzahlen oder Gleitkommazahlen.

Grund für das Fehlen von Funktionen zur Konvertierung von vorzeichenbehafteten Ganzzahlen

Das Fehlen von Funktionen zur Konvertierung von vorzeichenbehafteten Ganzzahlen ist in erster Linie darauf zurückzuführen auf die Tatsache, dass die Interpretation einer binären Darstellung als vorzeichenbehafteter oder vorzeichenloser Wert eine Frage der Programmierlogik ist. Das []Byte-Array selbst enthält nur rohe Binärdaten, die je nach den Anforderungen der Anwendung entweder als vorzeichenbehaftet oder ohne Vorzeichen interpretiert werden können.

So konvertieren Sie in vorzeichenbehaftete Ganzzahlen

Um einen vorzeichenlosen Ganzzahlwert in eine vorzeichenbehaftete Ganzzahl umzuwandeln, kann eine einfache Typkonvertierung verwendet werden. Da das Speicherlayout von vorzeichenlosen und vorzeichenbehafteten Ganzzahlen gleicher Größe identisch ist, bleibt beim Konvertieren von a von uint16 in int16 mit int16(a) die ursprüngliche Binärdarstellung erhalten, während das entsprechende Vorzeichen zugewiesen wird.

Konvertieren in Floats

Die Konvertierung von vorzeichenlosen Ganzzahlen in Floats erfordert etwas mehr Aufwand. Das Math-Paket stellt hierfür Funktionen bereit: math.Float32frombits() und math.Float64frombits(). Umgekehrt können math.Float32bits() und math.Float64bits() verwendet werden, um die vorzeichenlose Ganzzahldarstellung von Float-Werten zu erhalten.

Verwendung von Binary.Read() und Binary.Write()

Das Binärpaket enthält auch die Funktionen Read() und Write(), die diese Konvertierungen unter der Haube effizienter durchführen können. Mit diesen Funktionen können Sie direkt in einen typisierten Wert einlesen, ohne dass zwischenzeitliche Typkonvertierungen erforderlich sind.

Beispiel für die Verwendung von Binary.Read() für die Float-Konvertierung

Bedenken Sie Folgendes Beispiel:

<code class="go">b := []byte{0x18, 0x2d, 0x44, 0x54, 0xfb, 0x21, 0x09, 0x40}

var pi float64
buf := bytes.NewReader(b)
err := binary.Read(buf, binary.LittleEndian, &pi)
if err != nil {
    fmt.Println("binary.Read failed:", err)
}

fmt.Println(pi) // Output: 3.141592653589793</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann ich Byte-Arrays in Go in vorzeichenbehaftete Ganzzahlen und Gleitkommazahlen konvertieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage