Table des matières
Chaîne de portée
Fermeture
Maison interface Web js tutoriel Une brève analyse de la compréhension des fermetures avec des exemples

Une brève analyse de la compréhension des fermetures avec des exemples

Apr 02, 2018 am 10:47 AM
闭包

Cet article partage avec vous une brève compréhension des fermetures. Le contenu est assez bon, j'espère qu'il pourra aider les amis dans le besoin

Chaîne de portée

Pour comprendre. fermetures plus clairement, vous devez d'abord bien comprendre la chaîne de portée, afin que la compréhension des fermetures soit beaucoup plus facile.

Une chaîne de portées est une liste qui pointe vers différents espaces de stockage de variables. Elle est généralement entourée globalement par l'environnement variable de la fenêtre.

L'attribut [[scope]] de chaque environnement d'exécution stocke une référence à la chaîne de portée.

var name = "tianci";
Copier après la connexion

Lorsque nous avons fini d'exécuter le code ci-dessus, l'attribut window.name dans le navigateur est "tianci". À ce stade, la variable pointée par la liste de portées pointée par window[[scope] ] L'espace a le nom : "tianci" existe

var name = "tianci";
function sy() {
    var name = "haha";
    console.log(name);
}
sy();//haha
Copier après la connexion

Dans ce code, lors de l'exécution de sy(), la liste de portées pointée par [[scope]] de l'environnement d'exécution sy changera d'abord de fenêtre Copier la liste de portées dans sa propre liste et insérez l'espace variable sy dans l'en-tête de la liste de portées (c'est-à-dire la position de list.[0]). Lorsque name est exécuté, la variable name sera interrogée dans la liste, 0->1 -> 2 ->3... jusqu'à l'environnement de variable de niveau supérieur.

var name = "tianci";
function sy() {
    var name = "haha";
    console.log(name);
    console.log(this.name);
}
sy();

//haha
//tianci
Copier après la connexion

Les deux sorties sont différentes

log(name). Lorsque la fonction sy trouve pour la première fois le nom de son propre environnement, elle génère haha

log(this.name). ), celui-ci de sy pointe vers window (dans le navigateur), donc la requête démarrera à partir de l'environnement de fenêtre pour trouver le nom, donc la sortie est tianci

1. La chaîne de portée est un point vers le stockage de plusieurs objets. Liste des espaces,

2. Chaque fois qu'une fonction est appelée, elle copiera d'abord la chaîne de portée de l'appelant dans sa propre chaîne de portée, puis insérera sa propre portée en tête de la liste chaînée

Fermeture

La fermeture n'est pas difficile à comprendre. Le concept de fermeture est une fonction qui a accès à des variables dans la portée d'une autre fonction. La façon courante de la créer est de la créer dans Hanshu. tels que :

function cC(property) {
    return function (obj1,obj2) {        var value1 = obj1[property]
        var value2 = obj2[property]
        if (value1 < value2) {
            return -1;
        }else if(value1 > value2){
            return 1;
        }else if(value1 == value2){
            return 0;
        }
    }
}
Copier après la connexion

Ici, dans la fonction anonyme, on accède à la propriété variable de la fonction appelante, qui est la fermeture

Mais il y a un problème avec les fermetures, c'est-à-dire quand cC Si la fonction anonyme ne se termine pas après l'exécution, l'objet d'activité de l'environnement cC ne sera pas détruit. Il ne sera détruit qu'après l'exécution de la fonction anonyme. Par conséquent, les fermetures provoquent parfois des fuites de mémoire inutiles

Habituellement, l'objet this de la fonction anonyme pointe vers la fenêtre (dans le navigateur)

Car lorsque la fonction anonyme renvoyée est obtenue, elle est généralement est appelé directement dans l'environnement global, donc cela pointera vers la fenêtre à ce moment-là.

var name = "chentainci";
var obj ={
    name:"myboj",
    getName:function () {
        return function () {
            return this.name
        }
    }
}
console.log(obj.getName()())
Copier après la connexion

La fermeture récupère juste la valeur finale de la variable

function fun() {
    var result =new Array();
    for (var i  = 0;i  < 10; i++) {
        result[i] = function () {
            return i
        }
    }
    return result;
}
Copier après la connexion

le résultat stocke une fonction dont la valeur de retour est la valeur finale de i 10

Recommandations associées :

Fermeture Qu'est-ce que la fermeture

Compréhension approfondie des fermetures js

Applications courantes des fermetures

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Quelle est la signification de la fermeture dans l'expression lambda C++ ? Quelle est la signification de la fermeture dans l'expression lambda C++ ? Apr 17, 2024 pm 06:15 PM

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.

Comment implémenter la fermeture dans une expression C++ Lambda ? Comment implémenter la fermeture dans une expression C++ Lambda ? Jun 01, 2024 pm 05:50 PM

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.

Quels sont les avantages et les inconvénients des fermetures dans les fonctions C++ ? Quels sont les avantages et les inconvénients des fermetures dans les fonctions C++ ? Apr 25, 2024 pm 01:33 PM

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.

Résoudre le problème de fuite de mémoire causé par les fermetures Résoudre le problème de fuite de mémoire causé par les fermetures Feb 18, 2024 pm 03:20 PM

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 Golang L'impact des pointeurs de fonction et des fermetures sur les performances de Golang Apr 15, 2024 am 10:36 AM

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.

Appels enchaînés et fermetures de fonctions PHP Appels enchaînés et fermetures de fonctions PHP Apr 13, 2024 am 11:18 AM

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.

Comment les fermetures sont-elles implémentées en Java ? Comment les fermetures sont-elles implémentées en Java ? May 03, 2024 pm 12:48 PM

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.

Comment éviter efficacement les fuites de mémoire dans les fermetures ? Comment éviter efficacement les fuites de mémoire dans les fermetures ? Jan 13, 2024 pm 12:46 PM

Comment éviter les fuites de mémoire lors des fermetures ? La fermeture est l'une des fonctionnalités les plus puissantes de JavaScript, qui permet l'imbrication de fonctions et l'encapsulation des données. Cependant, les fermetures sont également sujettes à des fuites de mémoire, en particulier lorsqu'il s'agit d'asynchrones et de minuteries. Cet article explique comment éviter les fuites de mémoire lors des fermetures et fournit des exemples de code spécifiques. Les fuites de mémoire se produisent généralement lorsqu'un objet n'est plus nécessaire, mais que la mémoire qu'il occupe ne peut pas être libérée pour une raison quelconque. Dans une fermeture, lorsqu'une fonction fait référence à des variables externes, et ces variables

See all articles