首頁 web前端 js教程 JavaScript避免記憶體外洩及記憶體管理技巧_javascript技巧

JavaScript避免記憶體外洩及記憶體管理技巧_javascript技巧

May 16, 2016 pm 04:36 PM
javascript 內存洩漏 記憶體管理 技巧

本文實例講述了JavaScript避免記憶體外洩及記憶體管理技巧,非常實用。分享給大家參考之用。具體方法如下:

本文內容源自GoogleWebPerf(倫敦WebPerf集團),2014年8月26日。

一般來說,高效率的JavaScript Web應用程式必須流暢,快速。與用戶互動的任何應用程序,都需要考慮如何確保記憶體有效使用,因為如果消耗過多,頁面就會崩潰,迫使用戶重新加載。而你只能躲在角落哭泣。

自動垃圾收集是不能取代有效的記憶體管理的,特別是在大型,長時間運行的Web應用程式中。本文中,我們將示範如何透過Chrome的DevTools對記憶體進行有效的管理。

並了解如何解決效能問題,如記憶體洩漏,頻繁的垃圾收集暫停,和整體記憶體膨脹,那些真正讓你耗費精力的東西。

Addy Osmani在他的PPT中展示了許多會在Chrome V8中產生記憶體洩漏的範例:

1) Delete一個Object的屬性會讓此物件變慢(多耗費15倍的記憶體)

var o = { x: 'y' };
delete o.x; //此时o会成一个慢对象
o.x; //
 
var o = { x: 'y' };
o = null; //应该这样

登入後複製

2) 閉包

在閉包中引入閉包外部的變數時,當閉包結束時此物件無法被垃圾回收(GC)。

var a = function() {
 var largeStr = new Array(1000000).join('x');
 return function() {
  return largeStr;
 }
}();

登入後複製

3) DOM外洩

當原有的COM被移除時,子結點引用沒有被移除則無法回收。

var select = document.querySelector;
var treeRef = select('#tree');
 
//在COM树中leafRef是treeFre的一个子结点
var leafRef = select('#leaf'); 
var body = select('body');
 
body.removeChild(treeRef);
 
//#tree不能被回收入,因为treeRef还在
//解决方法:
treeRef = null;
 
//tree还不能被回收,因为叶子结果leafRef还在
leafRef = null;
 
//现在#tree可以被释放了。

登入後複製

4) Timers計(定)時器外洩

定時器也是常見產生記憶體外洩的地方:

for (var i = 0; i < 90000; i++) {
 var buggyObject = {
  callAgain: function() {
   var ref = this;
   var val = setTimeout(function() {
    ref.callAgain();
   }, 90000);
  }
 }
 
 buggyObject.callAgain();
 //虽然你想回收但是timer还在
 buggyObject = null;
}

登入後複製

5) 除錯記憶體

Chrome自帶的記憶體偵錯工具可以很方便地查看記憶體使用情況和記憶體外洩:

在 Timeline -> Memory 點選record即可:

希望本文所述對大家javascript程式設計的學習有所幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

C++物件佈局與記憶體對齊,優化記憶體使用效率 C++物件佈局與記憶體對齊,優化記憶體使用效率 Jun 05, 2024 pm 01:02 PM

C++物件佈局和記憶體對齊優化記憶體使用效率:物件佈局:資料成員按聲明順序存儲,優化空間利用率。記憶體對齊:資料在記憶體中對齊,提升存取速度。 alignas關鍵字指定自訂對齊,例如64位元組對齊的CacheLine結構,提高快取行存取效率。

golang函數記憶體洩漏檢測與解決 golang函數記憶體洩漏檢測與解決 Apr 23, 2024 pm 05:09 PM

Go語言中存在函數記憶體洩露,它會導致應用程式記憶體不斷消耗和崩潰。我們可以使用runtime/pprof套件進行偵測,並檢查函數是否意外保留了對不需要資源的參考。要解決記憶體洩露,我們需要找到導致洩露的引用,通常透過檢查函數程式碼和尋找全域變數或閉包引用來實現。

C++ 記憶體管理:自訂記憶體分配器 C++ 記憶體管理:自訂記憶體分配器 May 03, 2024 pm 02:39 PM

C++中的自訂記憶體分配器可讓開發者根據需求調整記憶體分配行為,建立自訂分配器需要繼承std::allocator並重寫allocate()和deallocate()函式。實戰案例包括:提高效能、優化記憶體使用和實現特定行為。使用時需要注意避免釋放內存,管理內存對齊,並進行基準測試。

C++ 記憶體管理在多執行緒環境中的挑戰與應對措施? C++ 記憶體管理在多執行緒環境中的挑戰與應對措施? Jun 05, 2024 pm 01:08 PM

在多執行緒環境中,C++記憶體管理面臨以下挑戰:資料競爭、死鎖和記憶體洩漏。因應措施包括:1.使用同步機制,如互斥鎖和原子變數;2.使用無鎖資料結構;3.使用智慧指標;4.(可選)實現垃圾回收。

C++ 記憶體管理如何與作業系統和虛擬記憶體互動? C++ 記憶體管理如何與作業系統和虛擬記憶體互動? Jun 02, 2024 pm 09:03 PM

C++記憶體管理與作業系統交互,透過作業系統管理實體記憶體和虛擬內存,為程式高效分配和釋放記憶體。作業系統將實體記憶體劃分為頁面,並按需從虛擬記憶體中調入應用程式請求的頁面。 C++使用new和delete運算子分配和釋放內存,分別向作業系統請求內存頁並將其返回。作業系統在釋放實體記憶體時,將較少使用的記憶體頁交換到虛擬記憶體。

golang函數的記憶體管理最佳實踐 golang函數的記憶體管理最佳實踐 Apr 26, 2024 pm 05:33 PM

Go中的記憶體管理最佳實踐包括:避免手動分配/釋放記憶體(使用垃圾收集器);使用記憶體池提高經常建立/銷毀物件時的效能;使用引用計數追蹤共享資料的參考數量;使用同步記憶體池sync.Pool在並發場景下安全管理物件。

C++記憶體管理中的引用計數機制 C++記憶體管理中的引用計數機制 Jun 01, 2024 pm 08:07 PM

引用計數機制在C++記憶體管理中用於追蹤物件的引用情況並自動釋放未使用記憶體。此技術為每個物件維護一個引用計數器,當引用新增或移除時計數器會相應增減。當計數器降為0時,物件被釋放,無需手動管理。但循環引用會導致記憶體洩漏,維護引用計數器會增加開銷。

PHP 函數中如何管理記憶體佔用? PHP 函數中如何管理記憶體佔用? Apr 26, 2024 pm 12:12 PM

PHP函數中管理記憶體佔用需:避免宣告不必要的變數;使用輕量級資料結構;釋放未使用的變數;最佳化字串處理;限制函數參數;最佳化循環和條件,例如避免死循環和使用索引數組。

See all articles