さまざまな印刷出力の奇妙なケース: *bytes.Buffer と bytes.Buffer
Go でバイトを扱う場合、ポインター値と非ポインター値の間の微妙な違いにより、予期しない印刷結果が生じる可能性があります。
次を実行するとコード:
buf := new(bytes.Buffer) buf.WriteString("Hello World") fmt.Println(buf)
おなじみの出力「Hello World」が表示されます。これは、*bytes.Buffer のようなポインター値の場合、Go はその値に String() メソッドがあるかどうかをチェックするためです。この場合、*bytes.Buffer は String() を実装しており、その呼び出しによりバッファーの内容が文字列として出力されます。
ただし、同じコードが bytes.Buffer のような非ポインター値に対して実行されると、動作が異なります。 :
var buf bytes.Buffer buf.WriteString("Hello World") fmt.Println(buf)
期待される文字列表現の代わりに、次のようになります。出力:
{[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
この一見不可解な出力は、バイトのメモリ レイアウトを表します。フィールドとパディング バイトを含むバッファ構造体。
この違いの理由は、Go の処理方法にあります。値の印刷。出力される値に String() メソッドがあるかどうかを確認し、存在する場合はそれを使用して文字列表現を取得します。ポインター型 *bytes.Buffer の場合、String() メソッドが存在するため、その内容は文字列として出力されます。ただし、非ポインター型 bytes.Buffer の場合、String() メソッドは実装されていないため、個々のフィールドはデフォルトの書式設定になります。
作業時に予期せぬ事態を避けるために、この区別を念頭に置くことが重要です。 Go のバイトとバッファーを使用します。ポインター値と非ポインター値のさまざまな動作を理解すると、より予測可能で堅牢なコードを作成するのに役立ちます。
以上がGo で `fmt.Println` が `*bytes.Buffer` と `bytes.Buffer` に対して異なる出力を表示するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。