Table des matières
1. Variables globales
2. Fermeture
3. Le retardateur/minuterie oublié
Lorsque le dom est effacé ou supprimé, l'événement n'est pas effacé)" >4. Références d'éléments DOM qui ne sont pas nettoyées (Lorsque le dom est effacé ou supprimé, l'événement n'est pas effacé)
Maison interface Web Questions et réponses frontales Quelles sont les causes des fuites de mémoire JavaScript ?

Quelles sont les causes des fuites de mémoire JavaScript ?

Nov 19, 2021 pm 04:37 PM
javascript 内存泄漏

Causes des fuites de mémoire JavaScript : 1. Mauvaise utilisation des variables globales ; 2. Mauvaise utilisation des fermetures ; 3. Les retards ou les minuteries ne sont pas effacés ; 4. Les références d'éléments DOM qui ne sont pas nettoyées (lorsque le dom est effacé ou supprimé, événements non effacés).

Quelles sont les causes des fuites de mémoire JavaScript ?

L'environnement d'exploitation de ce tutoriel : système Windows 7, JavaScript version 1.8.5, ordinateur Dell G3.

Une fuite de mémoire signifie qu'une partie de la mémoire allouée ne peut pas être utilisée ou recyclée jusqu'à la fin du processus du navigateur. Cela signifie qu'en raison d'une négligence ou d'une erreur, le programme ne parvient pas à libérer la mémoire qui n'est plus utilisée. Les fuites de mémoire ne font pas référence à la disparition physique de la mémoire, mais plutôt au fait qu'après que l'application ait alloué un certain segment de mémoire, en raison d'erreurs de conception, elle perd le contrôle du segment de mémoire avant de libérer le segment de mémoire, ainsi provoquant un gaspillage de mémoire. Voici quelques causes courantes de fuites de mémoire.

1. Variables globales

JavaScript peut gérer des variables non déclarées : une référence à une variable non déclarée crée une nouvelle variable dans l'objet global. Dans le contexte d'un navigateur, l'objet global est window.

function foo(){
  name = '前端曰';
}
// 其实是把name变量挂载在window对象上
function foo(){
  window.name = '前端曰';
}

// 又或者
function foo(){
  this.name = '前端曰';
}
foo() // 其实这里的this就是指向的window对象
Copier après la connexion

De cette façon, une variable globale inattendue est créée involontairement. Pour éviter que cette erreur ne se produise, ajoutez « use strict ; » au début de votre fichier Javascript. Cela active un mode d'analyse JavaScript plus strict qui empêche les globaux inattendus. Ou faites attention à la définition des variables vous-même !

2. Fermeture

Closure : les fonctions anonymes peuvent accéder aux variables dans la portée parent.

var names = (function(){  
    var name = 'js-say';
    return function(){
        console.log(name);
    }
})()
Copier après la connexion

La fermeture entraînera la séparation du cycle de vie de la référence d'objet du contexte de la fonction actuelle. Si la fermeture est mal utilisée, elle peut conduire à une référence circulaire (référence circulaire), similaire à un blocage, qui peut. seulement être évité et ne peut pas être résolu une fois qu'il s'est produit, même s'il y a des déchets, le recyclage provoquera toujours des fuites de mémoire.

3. Le retardateur/minuterie oublié

Dans nos besoins quotidiens, nous essayons souvent setInterval/setTimeout, mais nous oublions généralement de le nettoyer après utilisation.

var someResource = getData(); 
setInterval(function() { 
    var node = document.getElementById('Node'); 
    if(node) { 
        // 处理 node 和 someResource 
        node.innerHTML = JSON.stringify(someResource)); 
    } 
}, 1000);
Copier après la connexion

Ceci dans setInterval/setTimeout pointe vers l'objet window, donc les variables définies en interne sont également montées globalement ; la variable someResource est référencée dans le if, et si setInterval/setTimeout n'est pas effacé, someResource ne sera pas libérée de la même manière ; en fait, il en va de même pour setTimeout. Nous devons donc nous rappeler de clearInterval/clearTimeout une fois terminé.

4. Références d'éléments DOM qui ne sont pas nettoyées (Lorsque le dom est effacé ou supprimé, l'événement n'est pas effacé)

var elements = {
    button: document.getElementById('button'),
    image: document.getElementById('image'),
    text: document.getElementById('text')
};
function doStuff() {
    image.src = 'http://some.url/image';
    button.click();
    console.log(text.innerHTML);
}
function removeButton() {
    document.body.removeChild(document.getElementById('button'));
    // 此时,仍旧存在一个全局的 #button 的引用
    // elements 字典。button 元素仍旧在内存中,不能被 GC 回收。
}
Copier après la connexion

[Apprentissage recommandé : Tutoriel avancé javascript]

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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
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)

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

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.

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

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