ホームページ >バックエンド開発 >Golang >コンパイル時に埋め込み構造体の String() メソッド呼び出しのあいまいさを検出しないのはなぜですか?

コンパイル時に埋め込み構造体の String() メソッド呼び出しのあいまいさを検出しないのはなぜですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-26 03:05:10236ブラウズ

Why Doesn't Go Detect Ambiguity in String() Method Invocation for Embedded Structs at Compile Time?

Go の埋め込み構造体の奇妙なメソッド呼び出し: String() について

Go では、埋め込み構造体はその埋め込み型のメソッドを継承します。ただし、複数の埋め込み型が同じ名前のメソッドを定義すると、あいまいさが生じます。特に String() メソッドに焦点を当てて、この動作を調べてみましょう。

提供されたコード例では、

type Engineer struct {
    Person
    TaxPayer
    Specialization string
}

type Person struct {
    Name string
    Age  int
}

func (p Person) String() string {
    return fmt.Sprintf("name: %s, age: %d", p.Name, p.Age)
}

type TaxPayer struct {
    TaxBracket int
}

func (t TaxPayer) String() string {
    return fmt.Sprintf("%d", t.TaxBracket)
}

エンジニア構造体が fmt.Println(engineer) を使用して出力されると、出力は、埋め込み型に String() メソッドが存在するかどうかによって異なります。

With Person.String():

  • fmt は、Engineer タイプの中で最も深さが浅いため、Person.String() を呼び出します。
  • 出力は次のようになります: "{name: John Doe、年齢: 35 3 Construction}"

なしPerson.String():

  • fmt は、昇格された唯一の String() メソッドであるため、TaxPayer.String() を呼び出します。
  • 出力は次のようになります: "3"

両方の String() なしメソッド:

  • 埋め込み型から String() メソッドを昇格することはできません。
  • fmt はデフォルトのフィールド値を出力します: "{{John Doe 35} {3} Construction}"

これらのシナリオは、Go のプロモートされたメソッドの深さルールと曖昧さの解決に焦点を当てています。ただし、深さが 0 の String() メソッドが複数存在する場合、なぜコンパイル時にあいまいさが検出されないのかという疑問が生じます。

Ambiguous Selector Check:

通常、engineer.Foo() などのあいまいなセレクターを使用してメソッドを呼び出そうとすると、コンパイル時エラーが発生します。ただし、これは String() という名前のメソッドでは発生しません。

理由:

String() メソッドを明示的に呼び出さずに値を出力する場合、fmt.Println関数は、値が fmt.Stringer を実装しているかどうかをチェックします。次に、実装された String() メソッドを呼び出します。すべての Go 型はデフォルトで暗黙的に Stringer を実装するため (https://golang.org/doc/go1.19#fmt)、どの型に対しても常に昇格された String() メソッドが存在します。

結論:

埋め込み構造体のメソッド呼び出しのあいまいさは、深さのルールと、値を出力するための String() メソッド。これらのルールとメソッド プロモーションの微妙な違いを理解することで、開発者は予期しない動作を回避し、Go プログラムのコードの明瞭さを維持できます。

以上がコンパイル時に埋め込み構造体の String() メソッド呼び出しのあいまいさを検出しないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。