Maison  >  Article  >  développement back-end  >  Pourquoi ne puis-je pas définir des fonctions imbriquées dans Go, mais puis-je définir des structures imbriquées ?

Pourquoi ne puis-je pas définir des fonctions imbriquées dans Go, mais puis-je définir des structures imbriquées ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-03 23:44:30923parcourir

Why Can't I Define Nested Functions in Go, but I Can Define Nested Structures?

Go : Classes imbriquées au sein des fonctions

Dans Go, il est possible de définir des structures imbriquées à l'intérieur des fonctions, comme le démontre le bloc de code :

<code class="go">func f() {
    // Nested struct Cls inside f
    type Cls struct {
        ...
    }
}</code>

Cependant, il n'est pas possible de déclarer des fonctions imbriquées au sein des fonctions, à l'exception des fonctions lambda. Cela peut sembler inhabituel étant donné la prise en charge des structures imbriquées.

Alternatives et solutions de contournement

Bien qu'il ne soit pas possible de définir des fonctions imbriquées au sens traditionnel, il existe des approches alternatives pour obtenir une fonctionnalité similaire :

1. Littéraux de fonction :

Les littéraux de fonction vous permettent de définir une fonction anonyme et de la stocker dans une variable. Cette fonction peut ensuite être utilisée comme argument d'une autre fonction, ou dans la fonction dans laquelle elle a été définie. Par exemple :

<code class="go">func f() {
    foo := func(s string) {
        fmt.Println(s)
    }

    foo("Hello World!")
}</code>

Dans cet exemple, un littéral de fonction est affecté à la variable foo dans le f fonction. Lorsque foo est appelé avec l'argument chaîne, il affiche "Hello World!" à la console.

2. Fermetures :

Les fermetures vous permettent de créer des fonctions qui ont accès à des variables définies dans la portée dans laquelle elles ont été créées. Cela vous permet d'"imbriquer" efficacement des fonctions en les définissant dans une fermeture. Par exemple :

<code class="go">func f() func(s string) {
    return func(s string) {
        fmt.Println(s)
    }
}

foo := f()
foo("Hello World!")</code>

Dans cet exemple, la fonction f renvoie un littéral de fonction qui a accès aux variables dans la portée de la fonction. Cela vous permet d'appeler la fonction renvoyée et de lui transmettre des arguments, même si elle a été définie dans f.

Il est important de noter que même si ces alternatives offrent une certaine flexibilité, elles ne sont pas les mêmes que les fonctions imbriquées traditionnelles.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn