Unterschiedliches Verhalten beim Drucken von bytes.Buffer in Go
In Go variiert das Verhalten beim Drucken eines Werts vom Typ bytes.Buffer je nach ob es sich um einen Zeigerwert oder einen Nichtzeigerwert handelt.
Bedenken Sie den folgenden Code Beispiel:
buf := new(bytes.Buffer) buf.WriteString("Hello world") fmt.Println(buf)
In diesem Fall ruft die Verwendung des *-Operators zum Dereferenzieren des Pufferzeigers die String()-Methode des Typs bytes.Buffer auf. Diese Methode gibt eine Zeichenfolgendarstellung des Pufferinhalts zurück, was dazu führt, dass „Hello World“ gedruckt wird.
Jetzt ändern wir den Code wie folgt:
var buf bytes.Buffer buf.WriteString("Hello world") fmt.Println(buf)
Ohne den *-Operator zu verwenden, Wir übergeben einen Nicht-Zeigerwert vom Typ bytes.Buffer. Anders als im vorherigen Beispiel ruft das fmt-Paket in diesem Fall nicht die Methode String() auf. Stattdessen wird der Puffer als Strukturwert unter Verwendung der Standardformatierung gedruckt:
{[72 101 108 108 111 32 119 111 114 108 100] 0 [72 101 108 108 111 32 119 111 114 108 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0] 0}
Diese Ausgabe stellt die interne Struktur des bytes.Buffer dar, einschließlich des Slice, das den Puffer unterstützt, sowie der Längen- und Kapazitätsfelder.
Der Hauptunterschied zwischen diesen beiden Beispielen liegt in der String()-Methode. Beim Drucken eines Werts vom Typ *bytes.Buffer verwendet das fmt-Paket die String()-Methode, um eine String-Darstellung des Pufferinhalts zu erhalten. Da der Nicht-Zeigerwert vom Typ bytes.Buffer diese Methode nicht hat, wird die Standardstrukturformatierung verwendet.
Das obige ist der detaillierte Inhalt vonWarum erzeugt das Drucken eines „bytes.Buffer' in Go unterschiedliche Ausgaben, je nachdem, ob es sich um einen Zeiger handelt oder nicht?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!