Heim >Backend-Entwicklung >Golang >## Wann und warum sollten Sie eine „unsichere' Konvertierung von „[]Byte' in „String' in Go vermeiden?
In Go ist die bevorzugte Methode zum Konvertieren eines Byte-Slice ([]Byte) in einen String:
<code class="go">var b []byte // fill b s := string(b)</code>
Dieser Ansatz erleichtert das Kopieren von Byte-Slices, was sich in leistungskritischen Situationen als problematisch erweisen kann.
Für solche Szenarien kann jedoch eine unsichere Konvertierung in Betracht gezogen werden:
<code class="go">var b []byte // fill b s := *(*string)(unsafe.Pointer(&b))</code>
Folgen einer unsicheren Konvertierung
Eine unsichere Konvertierung kann zwar tatsächlich die Leistung verbessern, es besteht jedoch das Risiko, dass die Unveränderlichkeitsgarantie von Strings in Go verletzt wird. Das Ändern einer Zeichenfolge, von der die Sprachspezifikation erwartet, dass sie unveränderlich ist, kann zu unerwartetem Verhalten führen. Im Folgenden sind einige mögliche Konsequenzen aufgeführt:
<code class="go">m := map[string]int{} b := []byte("hi") s := *(*string)(unsafe.Pointer(&b)) m[s] = 999 fmt.Println("Before:", m) b[0] = 'b' fmt.Println("After:", m) fmt.Println("But it's there:", m[s], m["bi"]) for i := 0; i < 1000; i++ { m[strconv.Itoa(i)] = i } fmt.Println("Now it's GONE:", m[s], m["bi"]) for k, v := range m { if k == "bi" { fmt.Println("But still there, just in a different bucket: ", k, v) } }</code>
Nachdem das erste Byte der Zeichenfolge in „b“ geändert wurde, ist sie weder mit dem ursprünglichen noch mit dem geänderten Schlüssel auffindbar. Die geänderte Zeichenfolge ist jedoch immer noch in der Karte vorhanden, wenn auch in einem anderen Bucket.
Das obige ist der detaillierte Inhalt von## Wann und warum sollten Sie eine „unsichere' Konvertierung von „[]Byte' in „String' in Go vermeiden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!