js 内存溢出 会怎样

2025-04-05 22:11:13
推荐回答(1个)
回答1:

JavaScript 中的内存泄漏
JavaScript 是一种垃圾收集式语言,这就是说,内存是根据对象的创建分配给该对象的,并会在没有对该对象的引用时由浏览器收回。JavaScript 的垃圾收集机制本身并没有问题,但浏览器在为 DOM 对象分配和恢复内存的方式上却有些出入。
Internet Explorer 和 Mozilla Firefox 均使用引用计数来为 DOM 对象处理内存。在引用计数系统,每个所引用的对象都会保留一个计数,以获悉有多少对象正在引用它。如果计数为零,该对象就会被销毁,其占用的内存也会返回给堆。虽然这种解决方案总的来说还算有效,但在循环引用方面却存在一些盲点。

原因
1)循环引用导致了内存泄漏

[xhtml] view plain copy



Div Element




2)由外部函数调用引起的内存泄漏

[xhtml] view plain copy


JS-->DOM
element.expandoProperty = this;
}
function Leak() {
//This code will leak
new myFunction(document.getElementById("myDiv"));
}
// -->







3)闭包引起的内存泄漏

[javascript] view plain copy
function parentFunction(paramA){
var a = paramA;
function childFunction(){
return a + 2;
}
return childFunction();
}

4)由事件处理引起的内存泄漏模式

[xhtml] view plain copy







解决方法
1)打破循环引用

[xhtml] view plain copy







2)添加另一个闭包

[xhtml] view plain copy







3)避免闭包自身

[xhtml] view plain copy









4)考虑用CollectGarbage()

[javascript] view plain copy
jcl.MemFree = function(Mem){
Mem = null;
CollectGarbage();
};

检测软件
sIEve: 他是基于ie的内存泄露检测工具,需要下载运行,http://home.wanadoo.nl/jsrosman/
Leak Monitor: 他是基于firefox的内存泄露检测工具,https://addons.mozilla.org/firefox/2490/

个人建议
内存回收机制本身有问题,所以开发人员开发的时候尽量减少内存溢出。不要盲目的追求完美!