ホームページ > バックエンド開発 > Golang > Go で `fmt.Println` が `*bytes.Buffer` と `bytes.Buffer` に対して異なる出力を表示するのはなぜですか?

Go で `fmt.Println` が `*bytes.Buffer` と `bytes.Buffer` に対して異なる出力を表示するのはなぜですか?

Susan Sarandon
リリース: 2024-11-22 14:20:34
オリジナル
404 人が閲覧しました

Why Does `fmt.Println` Show Different Outputs for `*bytes.Buffer` and `bytes.Buffer` in Go?

さまざまな印刷出力の奇妙なケース: *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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート