Go: 関数内のネストされたクラス
Go では、コード ブロックで示されているように、関数内にネストされた構造を定義できます。
<code class="go">func f() { // Nested struct Cls inside f type Cls struct { ... } }</code>
ただし、ラムダ関数を除き、関数内でネストされた関数を宣言することはできません。ネストされた構造のサポートを考えると、これは珍しいように思えるかもしれません。
代替案と回避策
従来の意味でネストされた関数を定義することはできませんが、代替のアプローチがあります。同様の機能を実現するには:
1.関数リテラル:
関数リテラルを使用すると、匿名関数を定義し、それを変数に格納できます。この関数は、別の関数への引数として、またはその関数が定義された関数内で使用できます。 例:
<code class="go">func f() { foo := func(s string) { fmt.Println(s) } foo("Hello World!") }</code>
この例では、関数リテラルが f 内の変数 foo に割り当てられます。関数。 foo が文字列引数を指定して呼び出されると、「Hello World!」が出力されます。コンソールへ。
2.クロージャ:
クロージャを使用すると、作成されたスコープ内で定義された変数にアクセスできる関数を作成できます。これにより、クロージャ内で関数を定義することにより、関数を効果的に「ネスト」することができます。例:
<code class="go">func f() func(s string) { return func(s string) { fmt.Println(s) } } foo := f() foo("Hello World!")</code>
この例では、関数 f は、関数のスコープ内の変数にアクセスできる関数リテラルを返します。これにより、関数が f.
内で定義されている場合でも、返された関数を呼び出して引数を渡すことができます。これらの代替方法はある程度の柔軟性を提供しますが、従来の入れ子関数と同じではないことに注意することが重要です。
以上がGo では入れ子構造を定義できるのに、入れ子関数を定義できないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。