Jadual Kandungan
1. Pembolehubah global
2. Penutupan
3. Penangguhan/pemasa yang terlupa
Apabila dom dikosongkan atau dipadamkan, acara tidak dikosongkan ) " >4. Rujukan elemen DOM yang tidak dibersihkan (Apabila dom dikosongkan atau dipadamkan, acara tidak dikosongkan )
Rumah hujung hadapan web Soal Jawab bahagian hadapan Apakah punca kebocoran memori javascript?

Apakah punca kebocoran memori javascript?

Nov 19, 2021 pm 04:37 PM
javascript kebocoran ingatan

Punca kebocoran memori JavaScript: 1. Penggunaan pembolehubah global yang tidak betul; 3. Kelewatan atau pemasa tidak dikosongkan 4. Rujukan elemen DOM yang tidak dikosongkan; acara tidak dikosongkan apabila dipadamkan).

Apakah punca kebocoran memori javascript?

Persekitaran pengendalian tutorial ini: sistem Windows 7, versi JavaScript 1.8.5, komputer Dell G3.

Kebocoran memori bermakna sekeping memori yang diperuntukkan tidak boleh digunakan atau dikitar semula sehingga proses penyemak imbas tamat. Ini bermakna kerana kecuaian atau ralat, program gagal mengeluarkan memori yang tidak digunakan lagi. Kebocoran memori tidak merujuk kepada kehilangan fizikal memori, tetapi lebih kepada fakta bahawa selepas aplikasi memperuntukkan segmen memori tertentu, disebabkan ralat reka bentuk, ia kehilangan kawalan ke atas segmen memori sebelum ia dikeluarkan, sehingga menyebabkan kerosakan ingatan. Berikut adalah beberapa punca biasa kebocoran ingatan.

1. Pembolehubah global

JavaScript boleh mengendalikan pembolehubah yang tidak diisytiharkan: rujukan kepada pembolehubah yang tidak diisytiharkan mencipta pembolehubah baharu dalam objek global. Dalam konteks penyemak imbas, objek global ialah tetingkap.

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

// 又或者
function foo(){
  this.name = '前端曰';
}
foo() // 其实这里的this就是指向的window对象
Salin selepas log masuk

Dengan cara ini, pembolehubah global yang tidak dijangka dibuat secara tidak sengaja Untuk mengelakkan ralat ini daripada berlaku, tambahkan 'use strict;' di hadapan fail Javascript anda. Ini membolehkan mod penghuraian JavaScript yang lebih ketat yang menghalang global yang tidak dijangka. Atau perhatikan sendiri definisi pembolehubah!

2. Penutupan

Penutupan: Fungsi tanpa nama boleh mengakses pembolehubah dalam skop induk.

var names = (function(){  
    var name = 'js-say';
    return function(){
        console.log(name);
    }
})()
Salin selepas log masuk

Penutupan akan menyebabkan kitaran hayat rujukan objek dipisahkan daripada konteks fungsi semasa Jika penutupan digunakan secara tidak betul, ia boleh membawa kepada rujukan bulat (rujukan bulat), serupa. kepada kebuntuan, yang hanya boleh dielakkan tetapi tidak boleh diselesaikan kemudian, walaupun terdapat kutipan sampah, masih akan berlaku kebocoran memori.

3. Penangguhan/pemasa yang terlupa

Dalam keperluan harian kita, kita mungkin sering mencuba setInterval/setTimeout, tetapi biasanya kita terlupa untuk membersihkannya selepas digunakan.

var someResource = getData(); 
setInterval(function() { 
    var node = document.getElementById('Node'); 
    if(node) { 
        // 处理 node 和 someResource 
        node.innerHTML = JSON.stringify(someResource)); 
    } 
}, 1000);
Salin selepas log masuk

Ini dalam setInterval/setTimeout menghala ke objek tetingkap, jadi pembolehubah yang ditakrifkan secara dalaman juga dipasang secara global jika pembolehubah someResource dirujuk, jika setInterval/setTimeout tidak dikosongkan, someResource juga perlu; untuk melepaskan; perkara yang sama berlaku untuk setTimeout. Jadi kita perlu ingat untuk clearInterval/clearTimeout apabila selesai.

4. Rujukan elemen DOM yang tidak dibersihkan (Apabila dom dikosongkan atau dipadamkan, acara tidak dikosongkan )

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 回收。
}
Salin selepas log masuk

[Pembelajaran yang disyorkan: Tutorial JavaScript Lanjutan]

Atas ialah kandungan terperinci Apakah punca kebocoran memori javascript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Go penjejakan kebocoran memori: Panduan praktikal Go pprof Go penjejakan kebocoran memori: Panduan praktikal Go pprof Apr 08, 2024 am 10:57 AM

Alat pprof boleh digunakan untuk menganalisis penggunaan memori aplikasi Go dan mengesan kebocoran memori. Ia menyediakan penjanaan profil memori, pengenalan kebocoran memori dan keupayaan analisis masa nyata. Hasilkan petikan memori dengan menggunakan pprof.Parse dan kenal pasti struktur data dengan peruntukan memori terbanyak menggunakan perintah pprof-allocspace. Pada masa yang sama, pprof menyokong analisis masa nyata dan menyediakan titik akhir untuk mengakses maklumat penggunaan memori dari jauh.

Selesaikan masalah kebocoran memori yang disebabkan oleh penutupan Selesaikan masalah kebocoran memori yang disebabkan oleh penutupan Feb 18, 2024 pm 03:20 PM

Tajuk: Kebocoran memori disebabkan oleh penutupan dan penyelesaian Pengenalan: Penutupan ialah konsep yang sangat biasa dalam JavaScript, yang membenarkan fungsi dalaman mengakses pembolehubah fungsi luaran. Walau bagaimanapun, penutupan boleh menyebabkan kebocoran memori jika digunakan secara tidak betul. Artikel ini akan meneroka masalah kebocoran memori yang disebabkan oleh penutupan dan menyediakan penyelesaian serta contoh kod khusus. 1. Kebocoran memori disebabkan oleh penutupan Ciri penutupan ialah fungsi dalaman boleh mengakses pembolehubah fungsi luaran, yang bermaksud pembolehubah yang dirujuk dalam penutupan tidak akan dikumpul sampah. Jika digunakan secara tidak betul,

Tutorial JavaScript Mudah: Cara Mendapatkan Kod Status HTTP Tutorial JavaScript Mudah: Cara Mendapatkan Kod Status HTTP Jan 05, 2024 pm 06:08 PM

Tutorial JavaScript: Bagaimana untuk mendapatkan kod status HTTP, contoh kod khusus diperlukan: Dalam pembangunan web, interaksi data dengan pelayan sering terlibat. Apabila berkomunikasi dengan pelayan, kami selalunya perlu mendapatkan kod status HTTP yang dikembalikan untuk menentukan sama ada operasi itu berjaya dan melaksanakan pemprosesan yang sepadan berdasarkan kod status yang berbeza. Artikel ini akan mengajar anda cara menggunakan JavaScript untuk mendapatkan kod status HTTP dan menyediakan beberapa contoh kod praktikal. Menggunakan XMLHttpRequest

Bagaimana untuk mengelakkan kebocoran memori dalam pengoptimuman prestasi teknikal Golang? Bagaimana untuk mengelakkan kebocoran memori dalam pengoptimuman prestasi teknikal Golang? Jun 04, 2024 pm 12:27 PM

Kebocoran memori boleh menyebabkan memori program Go terus meningkat dengan: menutup sumber yang tidak lagi digunakan, seperti fail, sambungan rangkaian dan sambungan pangkalan data. Gunakan rujukan yang lemah untuk mengelakkan kebocoran memori dan objek sasaran untuk pengumpulan sampah apabila ia tidak lagi dirujuk dengan kuat. Menggunakan go coroutine, memori tindanan coroutine akan dikeluarkan secara automatik apabila keluar untuk mengelakkan kebocoran memori.

Bagaimana untuk mengesan kebocoran memori menggunakan Valgrind? Bagaimana untuk mengesan kebocoran memori menggunakan Valgrind? Jun 05, 2024 am 11:53 AM

Valgrind mengesan kebocoran dan ralat memori dengan mensimulasikan peruntukan memori dan deallocation Untuk menggunakannya, ikuti langkah berikut: Pasang Valgrind: Muat turun dan pasang versi untuk sistem pengendalian anda daripada tapak web rasmi. Susun atur cara: Susun atur cara menggunakan bendera Valgrind (seperti gcc-g-omyprogrammyprogram.c-lstdc++). Analisis atur cara: Gunakan perintah valgrind--leak-check=fullmyprogram untuk menganalisis atur cara yang disusun. Semak output: Valgrind akan menjana laporan selepas pelaksanaan program, menunjukkan kebocoran memori dan mesej ralat.

Teknik nyahpepijat untuk kebocoran memori dalam C++ Teknik nyahpepijat untuk kebocoran memori dalam C++ Jun 05, 2024 pm 10:19 PM

Kebocoran memori dalam C++ bermakna program memperuntukkan memori tetapi terlupa untuk melepaskannya, menyebabkan memori tidak dapat digunakan semula. Teknik nyahpepijat termasuk menggunakan penyahpepijat (seperti Valgrind, GDB), memasukkan penegasan dan menggunakan pustaka pengesan kebocoran memori (seperti Boost.LeakDetector, MemorySanitizer). Ia menunjukkan penggunaan Valgrind untuk mengesan kebocoran memori melalui kes praktikal, dan mencadangkan amalan terbaik untuk mengelakkan kebocoran memori, termasuk: sentiasa melepaskan memori yang diperuntukkan, menggunakan penunjuk pintar, menggunakan perpustakaan pengurusan memori dan melakukan pemeriksaan memori biasa.

Bagaimana untuk mendapatkan kod status HTTP dalam JavaScript dengan cara yang mudah Bagaimana untuk mendapatkan kod status HTTP dalam JavaScript dengan cara yang mudah Jan 05, 2024 pm 01:37 PM

Pengenalan kepada kaedah mendapatkan kod status HTTP dalam JavaScript: Dalam pembangunan bahagian hadapan, kita selalunya perlu berurusan dengan interaksi dengan antara muka bahagian belakang, dan kod status HTTP adalah bahagian yang sangat penting daripadanya. Memahami dan mendapatkan kod status HTTP membantu kami mengendalikan data yang dikembalikan oleh antara muka dengan lebih baik. Artikel ini akan memperkenalkan cara menggunakan JavaScript untuk mendapatkan kod status HTTP dan memberikan contoh kod khusus. 1. Apakah kod status HTTP bermakna kod status HTTP apabila penyemak imbas memulakan permintaan kepada pelayan, perkhidmatan tersebut

Bagaimana untuk mengelakkan kebocoran memori dengan berkesan dalam penutupan? Bagaimana untuk mengelakkan kebocoran memori dengan berkesan dalam penutupan? Jan 13, 2024 pm 12:46 PM

Bagaimana untuk mengelakkan kebocoran memori dalam penutupan? Penutupan ialah salah satu ciri yang paling berkuasa dalam JavaScript, yang membolehkan sarang fungsi dan enkapsulasi data. Walau bagaimanapun, penutupan juga terdedah kepada kebocoran memori, terutamanya apabila berurusan dengan tak segerak dan pemasa. Artikel ini menerangkan cara untuk mengelakkan kebocoran memori dalam penutupan dan menyediakan contoh kod khusus. Kebocoran memori biasanya berlaku apabila objek tidak lagi diperlukan tetapi memori yang didudukinya tidak dapat dilepaskan atas sebab tertentu. Dalam penutupan, apabila fungsi merujuk kepada pembolehubah luaran, dan pembolehubah ini

See all articles