Le concept de fermeture en js
Les fermetures ne sont pas propres à JavaScript, la plupart des langages de haut niveau ont cette capacité.
Qu'est-ce qu'une fermeture ?
Une fermeture est la combinaison d'une fonction regroupée (enfermée) avec des références à son état environnant (l'environnement lexical).
ce Segment est la définition de la fermeture sur MDN, qui s'entend comme : une fonction et ses références environnantes dans l'environnement lexical fermé constituent une fermeture. Peut-être que cette phrase est encore difficile à comprendre. Jetez un œil à l'exemple :
function createAction() { var message = "封闭环境内的变量"; return function() { console.log(message); } } const showMessage = createAction(); showMessage(); // output: 封闭环境内的变量
Cet exemple est une fermeture typique. Il y a plusieurs points à noter :
-
showMessage
Oui. 🎜> UnecreateAction
fonction en est renvoyée après exécution. - est un environnement lexical fermé à l'intérieur
createAction
, en tant que variable au sein de cet environnement encapsulé, n'est jamais directement accessible de l'extérieur.message
- est exécuté à l'extérieur de
showMessage
, mais la variable localecreateAction
définie à l'intérieur est accessible pendant l'exécution (sortie réussie). En effet, la fonction référencée parmessage
(la fonction anonyme à l'intérieur deshowMessage
), lorsqu'elle est définie, est liée aux références (createAction
, etc.) dans l'environnement lexical (à l'intérieur decreateAction
) où elle se trouve .message
La fonction anonyme liée à l'environnement syntaxique interne est apportée par - pour être utilisée en dehors de l'environnement
return
fermé, qui forme une fermeture. S'il est appelé à l'intérieur decreateAction
, cela n'est pas considéré comme une fermeture.createAction
ne pensez pas que « vous » avez créé la fermeture, car les fermetures sont une fonctionnalité du langage, vous venez de profiter de cette fonctionnalité .
Si le langage ne prend pas en charge les fermetures, similaires au code ci-dessus, lorsque est exécuté, la variable showMessage
ne sera pas trouvée. Je veux surtout trouver un exemple, mais malheureusement, tous les langages de haut niveau que je connais semblent prendre en charge les fermetures tant que les fonctions peuvent être définies dans les fonctions/méthodes. message
Existe-t-il un autre moyen ? return
function encase(aCase) { const dog = "狗狗"; const cat = "猫猫"; aCase.show = function () { console.log(dog, cat); }; } const myCase = {}; encase(myCase); myCase.show(); // output: 猫猫 狗狗
pour amener les marchandises une par une, ou vous pouvez utiliser exports.something
pour emballer les marchandises, mais quoi qu'il en soit, module.exports = ...
est celui qui apporte les marchandises, mais il se peut que le exports
initialement prévu ait été remplacé par l'un des nôtres exports
. exports
et import
, qui n'est qu'une autre façon de faire ressortir les marchandises. C'est presque la même chose que export
. seulement Vous pouvez en apporter un (sauf si emballé), return
vous pouvez en apporter un tas. return
export
Il faut ajouter que qu'il s'agisse de CJS ou d'ESM, le module est un environnement encapsulé, et les éléments qui y sont définis ne sont pas accessibles de l'extérieur tant qu'ils ne sont pas retirés. Ceci est différent de l'environnement global par défaut des scripts Web. Veuillez faire attention à la différence.
Si exprimé en code, c'est probablement ce que je pensais lors de la définition du module :
const var1 = "我是一个顶层变量吧"; function maybeATopFunction() { }
Dans l'environnement d'exécution, cela ressemble en réalité à ceci (note : uniquement à titre d'illustration) :
// module factory function createModule_18abk2(exports, module) { const var1 = "我是一个顶层变量吧"; function maybeATopFunction() { } } // ... 遥远的生产线上,有这样的示意代码 const module = { exports: {} }; const m18abk2 = createModule_18abk2(module) ?? module; // 想明白 createModule_18abk2 为什么会有一个随机后缀没?
C'est toujours la même fonction ?
Si vous allez trop loin, ramenez-le. Réfléchissez à une question : théoriquement, une fonction est un bloc de code statique. La fonction de fermeture renvoyée en appelant plusieurs fois la fonction externe est-elle la même ?
Essayez :
function create() { function closure() { } return closure; } const a = create(); const b = create(); console.log(a === b); // false
Si vous êtes surpris, alors définissez
d'une autre manière pour voir si ce sera plus facile à comprendre :function create() { closure = function() { } return closure; }
closure()
Si vous pouvez toujours' Je n'ai pas compris, réessayez. Regardez ceci : function create() { const a = function () { }; const b = function () { }; console.log(a === b); // false }
Comprenez-vous ? À chaque fois,
définit une nouvelle fonction. La fonction est nouvelle et le nom n'a pas d'importance - vous pouvez l'appeler Xiao Ming, mais d'autres peuvent aussi l'appeler Xiao Ming.function
Donc, pour résumer :
Clôture, j'ai compris cette fois-ci !
Tutoriel recommandé : "Tutoriel JS
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

En C++, une fermeture est une expression lambda qui peut accéder à des variables externes. Pour créer une fermeture, capturez la variable externe dans l'expression lambda. Les fermetures offrent des avantages tels que la réutilisabilité, la dissimulation des informations et une évaluation paresseuse. Ils sont utiles dans des situations réelles telles que les gestionnaires d'événements, où la fermeture peut toujours accéder aux variables externes même si elles sont détruites.

Les expressions C++ Lambda prennent en charge les fermetures, qui enregistrent les variables de portée de fonction et les rendent accessibles aux fonctions. La syntaxe est [capture-list](parameters)->return-type{function-body}. capture-list définit les variables à capturer. Vous pouvez utiliser [=] pour capturer toutes les variables locales par valeur, [&] pour capturer toutes les variables locales par référence, ou [variable1, variable2,...] pour capturer des variables spécifiques. Les expressions Lambda ne peuvent accéder qu'aux variables capturées mais ne peuvent pas modifier la valeur d'origine.

Une fermeture est une fonction imbriquée qui peut accéder aux variables dans la portée de la fonction externe. Ses avantages incluent l'encapsulation des données, la conservation de l'état et la flexibilité. Les inconvénients incluent la consommation de mémoire, l’impact sur les performances et la complexité du débogage. De plus, les fermetures peuvent créer des fonctions anonymes et les transmettre à d'autres fonctions sous forme de rappels ou d'arguments.

Titre : Fuites de mémoire causées par les fermetures et solutions Introduction : Les fermetures sont un concept très courant en JavaScript, qui permettent aux fonctions internes d'accéder aux variables des fonctions externes. Cependant, les fermetures peuvent provoquer des fuites de mémoire si elles ne sont pas utilisées correctement. Cet article explorera le problème de fuite de mémoire provoqué par les fermetures et fournira des solutions et des exemples de code spécifiques. 1. Fuites de mémoire causées par les fermetures La caractéristique des fermetures est que les fonctions internes peuvent accéder aux variables des fonctions externes, ce qui signifie que les variables référencées dans les fermetures ne seront pas récupérées. S'il est mal utilisé,

L'impact des pointeurs de fonction et des fermetures sur les performances de Go est le suivant : Pointeurs de fonction : légèrement plus lents que les appels directs, mais améliorent la lisibilité et la réutilisabilité. Fermetures : généralement plus lentes, mais encapsulent les données et le comportement. Cas pratique : les pointeurs de fonction peuvent optimiser les algorithmes de tri et les fermetures peuvent créer des gestionnaires d'événements, mais ils entraîneront des pertes de performances.

Oui, la simplicité et la lisibilité du code peuvent être optimisées grâce à des appels et des fermetures enchaînés : les appels en chaîne lient les appels de fonction dans une interface fluide. Les fermetures créent des blocs de code réutilisables et accèdent à des variables en dehors des fonctions.

Les fermetures en Java permettent aux fonctions internes d'accéder aux variables de portée externe même si la fonction externe est terminée. Implémentée via des classes internes anonymes, la classe interne contient une référence à la classe externe et maintient les variables externes actives. Les fermetures augmentent la flexibilité du code, mais vous devez être conscient du risque de fuite de mémoire, car les références à des variables externes par des classes internes anonymes maintiennent ces variables en vie.

Les fermetures de fonctions du langage Go jouent un rôle essentiel dans les tests unitaires : Capture de valeurs : les fermetures peuvent accéder aux variables dans la portée externe, permettant ainsi de capturer et de réutiliser les paramètres de test dans des fonctions imbriquées. Simplifiez le code de test : en capturant les valeurs, les fermetures simplifient le code de test en éliminant le besoin de définir des paramètres à plusieurs reprises pour chaque boucle. Améliorez la lisibilité : utilisez des fermetures pour organiser la logique de test, rendant ainsi le code de test plus clair et plus facile à lire.
