Table des matières
3.2 Minuterie" >3.2 Minuterie
3.3 多处引用" >3.3 多处引用
3.4 闭包" >3.4 闭包
Maison interface Web js tutoriel Fuites de mémoire courantes en JavaScript

Fuites de mémoire courantes en JavaScript

Nov 09, 2020 pm 05:31 PM
javascript 内存泄漏

Le didacticiel de la colonne

javascript présente les fuites de mémoire courantes.

Fuites de mémoire courantes en JavaScript

  • Avant-propos
  • 1 Introduction
  • 2 Les principales causes des fuites de mémoire
  • 3 Fuites de mémoire courantes
    • 3.1 Variables globales
    • 3.2 Minuterie
    • 3.3 Références multiples
    • 3.4 Fermeture
  • 4 Analyse de la mémoire Chrome Outil
  • Informations

Avant-propos

Lire ce blog Avant, vous aurez peut-être besoin avoir quelques connaissances en gestion de la mémoire JavaScript :

  • Gestion de la mémoire JavaScript et garbage collection en V8

1 Introduction

Fuites de mémoire : fait référence à la mémoire qui n'est plus nécessaire à l'application et qui n'est pas restituée au système d'exploitation pour une raison quelconque ou au pool de mémoire libre.

Problèmes possibles causés par des fuites de mémoire : ralentissement, décalage et latence élevée.

2 La principale cause des fuites de mémoire

La principale cause des fuites de mémoire JavaScript réside dans certaines références qui ne sont pas plus nécessaire ( Références indésirables).

Les références dites indésirables font référence à : certaines mémoires ne sont plus nécessaires aux développeurs, mais pour une raison quelconque, ces mémoires sont toujours marquées et restent dans l'arborescence racine active. Les références indésirables font référence aux références à ces souvenirs. Dans le contexte de JavaScript, les références indésirables sont des variables qui ne sont plus utilisées et pointent vers de la mémoire qui aurait pu être libérée.

3 Fuites de mémoire courantes

3.1 Variables globales

Tout d'abord, nous devons savoir que les variables globales en JavaScript sont référencées par le nœud racine, elles ne seront donc pas récupérées tout au long du cycle de vie de l'application.

Scénario 1 : En JavaScript, si vous référencez une variable non déclarée, cela entraînera la création d'une nouvelle variable dans l'environnement global.

function foo(arg) {    
bar = "this is a hidden global variable";
}
Copier après la connexion

La chaîne de code ci-dessus est en fait la suivante :

function foo(arg) {   
window.bar = "this is an explicit global variable";
}
Copier après la connexion

Supposons que nous voulions que la variable bar soit utilisée uniquement dans le cadre de la fonction foo, mais dans ce qui précède Dans ce cas, la création accidentelle d'une barre dans la portée globale entraînera une fuite de mémoire.

Scénario 2 :

function foo() {    
this.variable = "potential accidental global";
}foo();
Copier après la connexion

De même, si nous voulons que la barre de variables soit utilisée uniquement dans le cadre de la fonction foo, mais si nous ne savons pas que cela est à l'intérieur de la fonction foo pointe vers l'objet global, nous provoquerons une fuite de mémoire.

Recommandation :

  1. Évitez de créer accidentellement des variables globales. Par exemple, nous pouvons utiliser le mode strict, alors le premier morceau de code de cette section signalera une erreur et aucune variable globale ne sera créée.

  2. Réduire la création de variables globales.

  3. Si vous devez utiliser des variables globales pour stocker de grandes quantités de données, assurez-vous de les annuler ou de les réaffecter après le traitement des données.

3.2 Minuterie

Exemple de scène :

for (var i = 0; i < 100000; i++) 
{    
var buggyObject = {        
callAgain: function () {            
var ref = this;            
var val = setTimeout(function () 
{                
ref.callAgain();            
}, 10);        
}    
}    
buggyObject.callAgain();    
buggyObject = null;}
Copier après la connexion

3.3 多处引用

多处引用(Multiple references):当多个对象均引用同一对象时,但凡其中一个引用没有清除,都将导致被引用对象无法GC。

场景一:

var elements = 
{    
button: document.getElementById(&#39;button&#39;),    
image: document.getElementById(&#39;image&#39;),    
text: document.getElementById(&#39;text&#39;)};function doStuff() 
{    
image.src = &#39;http://some.url/image&#39;;    
button.click();    
console.log(text.innerHTML);    
// Much more logic}function removeButton() 
{    // The button is a direct child of body.    
document.body.removeChild(document.getElementById(&#39;button&#39;));    
// At this point, we still have a reference to #button in the global    
// elements dictionary. In other words, the button element is still in    
// memory and cannot be collected by the GC.s}
Copier après la connexion

在上面这种情况中,我们对#button的保持两个引用:一个在DOM树中,另一个在elements对象中。 如果将来决定回收#button,则需要使两个引用均不可访问。在上面的代码中,由于我们只清除了来自DOM树的引用,所以#button仍然存在内存中,而不会被GC。

场景二: 如果我们想要回收某个table,但我们保持着对这个table中某个单元格(cell)的引用,这个时候将导致整个table都保存在内存中,无法GC。

3.4 闭包

闭包(Closure):闭包是一个函数,它可以访问那些定义在它的包围作用域(Enclosing Scope)里的变量,即使这个包围作用域已经结束。因此,闭包具有记忆周围环境(Context)的功能。

场景举例:

var newElem;function outer() 
{   
var someText = new Array(1000000);   
var elem = newElem;   
function inner() 
{       if (elem) return someText;  
 }   
 return function () {};
 }setInterval(function ()
  {   newElem = outer();}, 5);
Copier après la connexion

在这个例子中,有两个闭包:一个是inner,另一个是匿名函数function () {}。其中,inner闭包引用了someText和elem,并且,inner永远也不会被调用。可是,我们需要注意:相同父作用域的闭包,他们能够共享context。 也就是说,在这个例子中,inner的someText和elem将和匿名函数function () {}共享。然而,这个匿名函数之后会被return返回,并且赋值给newElem。只要newElem还引用着这个匿名函数,那么,someText和elem就不会被GC。

同时,我们还要注意到,outer函数内部执行了var elem = newElem;,而这个newElem引用了上一次调用的outer返回的匿名函数。试想,第n次调用outer将保持着第n-1次调用的outer中的匿名函数,而这个匿名函数由保持着对elem的引用,进而保持着对n-2次的...因此,这将造成内存泄漏。

Solution : modifiez le code du paramètre 1 dans setInterval en newElem = outer()();

Pour une analyse détaillée de cette section, veuillez consulter Matériau 1 et Matériau 2.

4 Outil d'analyse de la mémoire Chrome

Outils de développement Chrome (dernière version 86) Deux outils d'analyse de la mémoire :

  1. Performances

  2. Mémoire

Recommandations d'apprentissage gratuites associées : javascript(vidéo)

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)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois 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)

Go suivi des fuites mémoire : guide pratique Go pprof Go suivi des fuites mémoire : guide pratique Go pprof Apr 08, 2024 am 10:57 AM

L'outil pprof peut être utilisé pour analyser l'utilisation de la mémoire des applications Go et détecter les fuites de mémoire. Il fournit des capacités de génération de profils de mémoire, d’identification des fuites de mémoire et d’analyse en temps réel. Générez un instantané de mémoire à l'aide de pprof.Parse et identifiez les structures de données avec le plus d'allocations de mémoire à l'aide de la commande pprof-allocspace. Dans le même temps, pprof prend en charge l'analyse en temps réel et fournit des points de terminaison permettant d'accéder à distance aux informations sur l'utilisation de la mémoire.

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é,

Tutoriel JavaScript simple : Comment obtenir le code d'état HTTP Tutoriel JavaScript simple : Comment obtenir le code d'état HTTP Jan 05, 2024 pm 06:08 PM

Tutoriel JavaScript : Comment obtenir le code d'état HTTP, des exemples de code spécifiques sont requis Préface : Dans le développement Web, l'interaction des données avec le serveur est souvent impliquée. Lors de la communication avec le serveur, nous devons souvent obtenir le code d'état HTTP renvoyé pour déterminer si l'opération a réussi et effectuer le traitement correspondant en fonction de différents codes d'état. Cet article vous apprendra comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournira quelques exemples de codes pratiques. Utilisation de XMLHttpRequest

Comment détecter les fuites de mémoire en utilisant Valgrind ? Comment détecter les fuites de mémoire en utilisant Valgrind ? Jun 05, 2024 am 11:53 AM

Valgrind détecte les fuites de mémoire et les erreurs en simulant l'allocation et la désallocation de mémoire. Pour l'utiliser, suivez ces étapes : Installez Valgrind : Téléchargez et installez la version correspondant à votre système d'exploitation à partir du site officiel. Compilez le programme : Compilez le programme à l'aide des indicateurs Valgrind (tels que gcc-g-omyprogrammyprogram.c-lstdc++). Analyser le programme : utilisez la commande valgrind--leak-check=fullmyprogram pour analyser le programme compilé. Vérifiez le résultat : Valgrind générera un rapport après l'exécution du programme, affichant les fuites de mémoire et les messages d'erreur.

Comment éviter les fuites de mémoire dans l'optimisation des performances techniques de Golang ? Comment éviter les fuites de mémoire dans l'optimisation des performances techniques de Golang ? Jun 04, 2024 pm 12:27 PM

Les fuites de mémoire peuvent entraîner une augmentation continue de la mémoire du programme Go en : fermant les ressources qui ne sont plus utilisées, telles que les fichiers, les connexions réseau et les connexions à la base de données. Utilisez des références faibles pour éviter les fuites de mémoire et ciblez les objets pour le garbage collection lorsqu'ils ne sont plus fortement référencés. En utilisant go coroutine, la mémoire de la pile de coroutines sera automatiquement libérée à la sortie pour éviter les fuites de mémoire.

Techniques de débogage pour les fuites de mémoire en C++ Techniques de débogage pour les fuites de mémoire en C++ Jun 05, 2024 pm 10:19 PM

Une fuite de mémoire en C++ signifie que le programme alloue de la mémoire mais oublie de la libérer, ce qui empêche la réutilisation de la mémoire. Les techniques de débogage incluent l'utilisation de débogueurs (tels que Valgrind, GDB), l'insertion d'assertions et l'utilisation de bibliothèques de détecteurs de fuite de mémoire (telles que Boost.LeakDetector, MemorySanitizer). Il démontre l'utilisation de Valgrind pour détecter les fuites de mémoire à travers des cas pratiques et propose les meilleures pratiques pour éviter les fuites de mémoire, notamment : toujours libérer la mémoire allouée, utiliser des pointeurs intelligents, utiliser des bibliothèques de gestion de la mémoire et effectuer des vérifications régulières de la mémoire.

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

Comment obtenir facilement le code d'état HTTP en JavaScript Comment obtenir facilement le code d'état HTTP en JavaScript Jan 05, 2024 pm 01:37 PM

Introduction à la méthode d'obtention du code d'état HTTP en JavaScript : Dans le développement front-end, nous devons souvent gérer l'interaction avec l'interface back-end, et le code d'état HTTP en est une partie très importante. Comprendre et obtenir les codes d'état HTTP nous aide à mieux gérer les données renvoyées par l'interface. Cet article explique comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournit des exemples de code spécifiques. 1. Qu'est-ce que le code d'état HTTP ? Le code d'état HTTP signifie que lorsque le navigateur lance une requête au serveur, le service

See all articles