本文介绍了关于“javascript内存泄漏的原因是什么”的知识。很多人在实际办案过程中都会遇到这样的困难。接下来,让边肖带领大家学习如何应对这些情况!希望大家认真阅读,学点东西!
javascript内存泄漏的原因如下:1。全局变量使用不当;2.瓶盖使用不当;3.延迟或计时器未被清除;4.没有清除的dom元素引用(当DOM被清除或删除时,事件不会被清除)。
本教程操作环境:windows7系统,javascript1.8.5版本1.8.5,戴尔G3电脑。
内存泄露是指一块被分配的内存既不能使用,又不能回收,直到浏览器进程结束。即指由于疏忽或错误造成程序未能释放已经不再使用的内存。内存泄漏并不是指内存的物理消失,而是应用程序分配了一定的内存后,由于设计错误造成的内存浪费,导致释放内存前失去对内存的控制。以下是内存泄漏的一些常见原因。
1. 全局变量
JavaScript可以处理未声明的变量:引用未声明的变量会在全局对象中创建新变量。在浏览器环境中,全局对象是窗口。
functionfoo(){ 0
名称='前置日期';
}
//实际上,name变量是挂载在窗口对象上的。
functionfoo(){ 0
Window.name='前置日期';
}
//或者
functionfoo(){ 0
This.name=' front date
}
fo()//实际上,这里是指向的window对象,所以意外创建了一个意外的全局变量。为了防止此错误,请添加“使用strict”到你的Javascript文件的前面。这为解析JavaScript打开了一个更严格的模式,以防止意外的全局。还是自己注意变量的定义吧!
00-1010闭包:匿名函数可以访问父作用域的变量。
varnames=(function(){ 0
varname=' js-say ';
return function(){ 0
console.log(名称);
}
})()闭包会导致对象引用的生命周期脱离当前函数的上下文。如果闭包使用不当,会导致循环引用,类似死锁,只能避免,发生后无法解决。即使有垃圾收集,内存仍然会泄漏。
00-1010在我们的日常需求中,我们可能经常尝试setInterval/setTimeout,但通常在使用后会忘记清理。
varsomesource=getData();
setInterval(函数(){ 0
varnode=document . getelementbyid(' Node ');
if(节点){ 0
//处理节点和某些资源
node . innerhtml=JSON . stringify(some resource));
}
},1000);这个in interval/settimeout指向窗口对象,所以内部定义的变量也被挂载到全局;if中引用了SomeResource变量,如果setInterval/setTimeout未清除,则无法释放some resource;其实setTimeout也是一样的。因此,当我们完成时,我们需要记住转到clearInterval/clearTimeout。
2. 闭包
varelements={ 0
button : document . getelementbyid(' button '),
image : document . getelementbyid(' image '),
text : document . getelementbyid(' text ')
};
functiondoStuff(){ 0
image . src=' http://some . URL/image ';
button . click();
console . log(text . innerhtml);
}
functionremoveButton(){ 0
document . body . remove child(document . getelementbyid(' button '));
//此时仍然有#button的全局引用。
//元素字典。按钮元素仍在内存中,无法被GC回收。
}“什么原因导致了}”JavaScript内存泄漏?“介绍到这里了。感谢阅读。如果你想了解更多的行业,可以关注网站。边肖将为您输出更多高质量的实用文章!
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/107923.html