Inhaltsverzeichnis
1. Globale Variablen
2. Abschluss
3. Der vergessene Verzögerer/Timer
Wenn der Dom gelöscht oder gelöscht wird, wird das Ereignis nicht gelöscht)" >4. DOM-Elementreferenzen, die nicht bereinigt werden (Wenn der Dom gelöscht oder gelöscht wird, wird das Ereignis nicht gelöscht)
Heim Web-Frontend Front-End-Fragen und Antworten Was sind die Ursachen für Javascript-Speicherlecks?

Was sind die Ursachen für Javascript-Speicherlecks?

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

Ursachen für JavaScript-Speicherlecks: 1. Unsachgemäße Verwendung globaler Variablen; 3. Verzögerungen oder Timer werden nicht gelöscht; Ereignisse nicht gelöscht).

Was sind die Ursachen für Javascript-Speicherlecks?

Die Betriebsumgebung dieses Tutorials: Windows 7-System, JavaScript-Version 1.8.5, Dell G3-Computer.

Ein Speicherverlust bedeutet, dass ein Teil des zugewiesenen Speichers nicht verwendet oder recycelt werden kann, bis der Browserprozess beendet ist. Dies bedeutet, dass das Programm aufgrund von Nachlässigkeit oder Fehlern nicht mehr verwendeten Speicher nicht freigibt. Speicherlecks bedeuten nicht das physische Verschwinden von Speicher, sondern dass die Anwendung, nachdem sie aufgrund von Designfehlern ein bestimmtes Speichersegment zugewiesen hat, die Kontrolle über das Speichersegment verliert, bevor sie das Speichersegment freigibt, was zu einer Verschwendung von Speicher führt . Hier sind einige häufige Ursachen für Speicherverluste.

1. Globale Variablen

JavaScript kann nicht deklarierte Variablen verarbeiten: Ein Verweis auf eine nicht deklarierte Variable erstellt eine neue Variable im globalen Objekt. Im Kontext eines Browsers ist das globale Objekt das Fenster.

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

// 又或者
function foo(){
  this.name = '前端曰';
}
foo() // 其实这里的this就是指向的window对象
Nach dem Login kopieren

Auf diese Weise wird unbeabsichtigt eine unerwartete globale Variable erstellt. Um zu verhindern, dass dieser Fehler auftritt, fügen Sie am Anfang Ihrer Javascript-Datei „use strict;“ hinzu. Dies ermöglicht einen strengeren Modus zum Parsen von JavaScript, der unerwartete Globals verhindert. Oder achten Sie selbst auf die Definition von Variablen!

2. Abschluss

Abschluss: Anonyme Funktionen können auf Variablen im übergeordneten Bereich zugreifen.

var names = (function(){  
    var name = 'js-say';
    return function(){
        console.log(name);
    }
})()
Nach dem Login kopieren

Das Schließen führt dazu, dass der Lebenszyklus der Objektreferenz vom Kontext der aktuellen Funktion getrennt wird. Bei unsachgemäßer Verwendung des Abschlusses kann es zu einem Zirkelverweis (Zirkelverweis) kommen, ähnlich einem Deadlock Es kann nur vermieden werden und kann nach dem Auftreten nicht mehr gelöst werden, selbst wenn Müll vorhanden ist. Das Recycling führt immer noch zu Speicherverlusten.

3. Der vergessene Verzögerer/Timer

In unserem täglichen Bedarf versuchen wir oft setInterval/setTimeout, vergessen aber normalerweise, ihn nach der Verwendung aufzuräumen.

var someResource = getData(); 
setInterval(function() { 
    var node = document.getElementById('Node'); 
    if(node) { 
        // 处理 node 和 someResource 
        node.innerHTML = JSON.stringify(someResource)); 
    } 
}, 1000);
Nach dem Login kopieren

Dies in setInterval/setTimeout zeigt auf das Fensterobjekt, sodass die intern definierten Variablen auch global bereitgestellt werden. Wenn setInterval/setTimeout nicht gelöscht wird, wird someResource ebenfalls nicht freigegeben. Tatsächlich gilt das Gleiche auch für setTimeout. Wir müssen also daran denken, „clearInterval/clearTimeout“ zu löschen, wenn wir fertig sind.

4. DOM-Elementreferenzen, die nicht bereinigt werden (Wenn der Dom gelöscht oder gelöscht wird, wird das Ereignis nicht gelöscht)

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 回收。
}
Nach dem Login kopieren

[Empfohlenes Lernen: Javascript-Tutorial für Fortgeschrittene]

Das obige ist der detaillierte Inhalt vonWas sind die Ursachen für Javascript-Speicherlecks?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Go-Speicherleckverfolgung: Go pprof-Praxisleitfaden Go-Speicherleckverfolgung: Go pprof-Praxisleitfaden Apr 08, 2024 am 10:57 AM

Mit dem pprof-Tool kann die Speichernutzung von Go-Anwendungen analysiert und Speicherlecks erkannt werden. Es bietet die Erstellung von Speicherprofilen, die Identifizierung von Speicherlecks und Funktionen zur Echtzeitanalyse. Erstellen Sie mit pprof.Parse einen Speicher-Snapshot und identifizieren Sie die Datenstrukturen mit den meisten Speicherzuweisungen mithilfe des Befehls pprof-allocspace. Gleichzeitig unterstützt pprof Echtzeitanalysen und stellt Endpunkte für den Fernzugriff auf Informationen zur Speichernutzung bereit.

Wie vermeidet man Speicherlecks bei der technischen Leistungsoptimierung von Golang? Wie vermeidet man Speicherlecks bei der technischen Leistungsoptimierung von Golang? Jun 04, 2024 pm 12:27 PM

Speicherlecks können dazu führen, dass der Speicher des Go-Programms kontinuierlich zunimmt, indem: Ressourcen geschlossen werden, die nicht mehr verwendet werden, wie z. B. Dateien, Netzwerkverbindungen und Datenbankverbindungen. Verwenden Sie schwache Referenzen, um Speicherlecks zu verhindern, und zielen Sie auf Objekte für die Garbage Collection ab, wenn sie nicht mehr stark referenziert sind. Bei Verwendung von Go-Coroutine wird der Speicher des Coroutine-Stapels beim Beenden automatisch freigegeben, um Speicherverluste zu vermeiden.

Lösen Sie das durch Schließungen verursachte Speicherverlustproblem Lösen Sie das durch Schließungen verursachte Speicherverlustproblem Feb 18, 2024 pm 03:20 PM

Titel: Durch Abschlüsse und Lösungen verursachte Speicherlecks Einführung: Abschlüsse sind ein sehr verbreitetes Konzept in JavaScript, das internen Funktionen den Zugriff auf Variablen externer Funktionen ermöglicht. Allerdings können Schließungen bei falscher Verwendung zu Speicherverlusten führen. In diesem Artikel wird das durch Schließungen verursachte Speicherverlustproblem untersucht und Lösungen sowie spezifische Codebeispiele bereitgestellt. 1. Durch Schließungen verursachte Speicherlecks Das Merkmal von Schließungen besteht darin, dass interne Funktionen auf Variablen externer Funktionen zugreifen können, was bedeutet, dass in Schließungen referenzierte Variablen nicht durch Müll gesammelt werden. Bei unsachgemäßer Verwendung

Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Jan 05, 2024 pm 06:08 PM

JavaScript-Tutorial: So erhalten Sie HTTP-Statuscode. Es sind spezifische Codebeispiele erforderlich. Vorwort: Bei der Webentwicklung ist häufig die Dateninteraktion mit dem Server erforderlich. Bei der Kommunikation mit dem Server müssen wir häufig den zurückgegebenen HTTP-Statuscode abrufen, um festzustellen, ob der Vorgang erfolgreich ist, und die entsprechende Verarbeitung basierend auf verschiedenen Statuscodes durchführen. In diesem Artikel erfahren Sie, wie Sie mit JavaScript HTTP-Statuscodes abrufen und einige praktische Codebeispiele bereitstellen. Verwenden von XMLHttpRequest

Wie erkennt man Speicherlecks mit Valgrind? Wie erkennt man Speicherlecks mit Valgrind? Jun 05, 2024 am 11:53 AM

Valgrind erkennt Speicherlecks und Fehler, indem es die Speicherzuweisung und -freigabe simuliert. Um es zu verwenden, befolgen Sie diese Schritte: Installieren Sie Valgrind: Laden Sie die Version für Ihr Betriebssystem von der offiziellen Website herunter und installieren Sie sie. Kompilieren Sie das Programm: Kompilieren Sie das Programm mit Valgrind-Flags (z. B. gcc-g-omyprogrammyprogram.c-lstdc++). Analysieren Sie das Programm: Verwenden Sie den Befehl valgrind--leak-check=fullmyprogram, um das kompilierte Programm zu analysieren. Überprüfen Sie die Ausgabe: Valgrind generiert nach der Programmausführung einen Bericht, der Speicherlecks und Fehlermeldungen anzeigt.

Debugging-Techniken für Speicherlecks in C++ Debugging-Techniken für Speicherlecks in C++ Jun 05, 2024 pm 10:19 PM

Ein Speicherverlust in C++ bedeutet, dass das Programm Speicher zuweist, aber vergisst, ihn freizugeben, wodurch der Speicher nicht wiederverwendet wird. Zu den Debugging-Techniken gehören die Verwendung von Debuggern (wie Valgrind, GDB), das Einfügen von Assertionen und die Verwendung von Bibliotheken zur Erkennung von Speicherlecks (wie Boost.LeakDetector, MemorySanitizer). Es demonstriert die Verwendung von Valgrind zur Erkennung von Speicherlecks anhand praktischer Fälle und schlägt Best Practices zur Vermeidung von Speicherlecks vor, darunter: Immer zugewiesenen Speicher freigeben, intelligente Zeiger verwenden, Speicherverwaltungsbibliotheken verwenden und regelmäßige Speicherprüfungen durchführen.

So erhalten Sie auf einfache Weise HTTP-Statuscode in JavaScript So erhalten Sie auf einfache Weise HTTP-Statuscode in JavaScript Jan 05, 2024 pm 01:37 PM

Einführung in die Methode zum Abrufen des HTTP-Statuscodes in JavaScript: Bei der Front-End-Entwicklung müssen wir uns häufig mit der Interaktion mit der Back-End-Schnittstelle befassen, und der HTTP-Statuscode ist ein sehr wichtiger Teil davon. Das Verstehen und Abrufen von HTTP-Statuscodes hilft uns, die von der Schnittstelle zurückgegebenen Daten besser zu verarbeiten. In diesem Artikel wird erläutert, wie Sie mithilfe von JavaScript HTTP-Statuscodes erhalten, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist ein HTTP-Statuscode? HTTP-Statuscode bedeutet, dass der Dienst den Dienst anfordert, wenn er eine Anfrage an den Server initiiert

Wie kann man Speicherlecks in Abschlüssen effektiv vermeiden? Wie kann man Speicherlecks in Abschlüssen effektiv vermeiden? Jan 13, 2024 pm 12:46 PM

Wie kann man Speicherlecks in Schließungen verhindern? Der Verschluss ist eine der leistungsstärksten Funktionen in JavaScript, die die Verschachtelung von Funktionen und die Kapselung von Daten ermöglicht. Schließungen sind jedoch auch anfällig für Speicherverluste, insbesondere bei asynchronen und Timer-Operationen. In diesem Artikel wird erläutert, wie Speicherlecks bei Abschlüssen verhindert werden, und es werden spezifische Codebeispiele bereitgestellt. Speicherlecks treten normalerweise auf, wenn ein Objekt nicht mehr benötigt wird, der von ihm belegte Speicher jedoch aus irgendeinem Grund nicht freigegeben werden kann. In einem Abschluss, wenn eine Funktion auf externe Variablen und diese Variablen verweist

See all articles