Maison >développement back-end >Golang >Comment convertir entre des structures Go et des tableaux d'octets : méthodes sûres et efficaces ?
Contexte :
En Go, le défi se pose lorsqu'on tente d'émuler C -opérations de conversion de type de style, telles que le mappage direct de la mémoire vers les structures. Cet article examinera les méthodes disponibles pour réaliser de telles conversions.
Type Casting avec unsafe.Pointer :
Historiquement, unsafe.Pointer était utilisé pour la manipulation directe de la mémoire. Cependant, il nécessite une conversion de type explicite et comporte des risques de sécurité en raison de son potentiel de corruption de la mémoire.
<code class="go">import "unsafe" type packet struct { opcode uint16 data [1024]byte } var pkt1 packet ... // Low-level type casting ptr := unsafe.Pointer(&pkt1) raddrPtr := (*uint32)(unsafe.Pointer(uintptr(ptr) + 2))</code>
Package d'encodage/binaire :
Pour répondre à ces problèmes, le package d’encodage/binaire offre une solution plus sûre et plus pratique. Ce package permet une sérialisation et une désérialisation efficaces des données à l'aide d'encodages prédéfinis tels que small-endian et big-endian.
<code class="go">// Encoding and decoding example package main import ( "bytes" "encoding/binary" "fmt" ) type T struct { A uint32 B float64 } func main() { // Create a struct and write it. t := T{A: 0xEEFFEEFF, B: 3.14} buf := &bytes.Buffer{} err := binary.Write(buf, binary.BigEndian, t) if err != nil { panic(err) } fmt.Println(buf.Bytes()) // Read into an empty struct. t = T{} err = binary.Read(buf, binary.BigEndian, &t) if err != nil { panic(err) } fmt.Printf("%x %f", t.A, t.B) }</code>
En utilisant le package encoding/binary, on peut gérer facilement la taille des données et les conversions endianness. , garantissant la sécurité du type et maintenant les performances.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!