手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >Javascript 闭包引起的IE内存泄露分析
Javascript 闭包引起的IE内存泄露分析
摘要:复制代码代码如下:functionfors(){obj_a=obj_b;obj_b.attr=obj_a;}复制代码代码如下:functio...

复制代码 代码如下:

function fors(){

obj_a = obj_b;

obj_b.attr = obj_a;

}

复制代码 代码如下:

function fors(){

obj_b = {};

obj_b.attr = obj_b;

}

上面是两个个很显示的循环引用,IE中产生了内存泄露,由于IE的内存回收机制,导至会长期占用内存而不能释放。

但闭包的内存泄露,有些隐蔽。因为闭包的循环引用,是间接的。

复制代码 代码如下:

function iememery(){

var js_obj = document.createElement("div");

js_obj.oncontextmenu = function(){ return false;}

}

<body onload="iememery()">

从表面上看,没有任何循环引用。但上面是一个闭包,根据闭包的特性,内部函数有权访问外部函数的变量对象。所以当iememery()执行之后:

js_obj是一个DOM元素的引用,DOM元素它长期在网页当中,不会消失,而这个DOM元素的一属性oncontextmenu,又是内部的函数引用(闭包),而这个匿名函数又和js_obj之间有隐藏的关联(作用域链)

所以形成了一个,循环引用.即:

js_obj.oncontextmenu 间接引用到 js_obj 也就是说,这个对象的一个属性,又间接的引用了自己。

只要有循环引用,就会在IE下产生内存泄露。打开你的windows任务管理器,在IE中不停刷新含有这个代码的html页面,看看Iexploer进程的内存占用情况,一直上升,且不会自动回收(降低);

解决办法:

复制代码 代码如下:

function iememery(){

var js_obj = document.createElement("div");

js_obj.oncontextmenu = function(){ return false;};js_obj.oncontextmenu = null;//加上这句,断开引用 }

当IE中发生js对象与dom对象直接的循环引用,并且之后没有引用指向他们,

如果是IE 6, 内存泄漏,直到关闭IE进程为止

如果是IE 7,内存泄漏, 直到离开当前页面为止

如果是IE 8, GC回收器回收他们的内存,无论当前是不是compatibility模式。

之前的IE js引擎里的GC回收器只能处理js对象,不能处理DOM对象。

【Javascript 闭包引起的IE内存泄露分析】相关文章:

javaScript中push函数用法实例分析

Javascript递归打印Document层次关系实例分析

Javascript实现div的toggle效果实例分析

Javascript的IE和Firefox兼容性汇编

JavaScript里实用的原生API汇总

浅谈javascript中的闭包

javascript获取select值的方法分析

JavaScript中指定函数名称的相关方法

Javascript 字符串模板的简单实现

javascript验证邮件地址和MX记录的方法

精品推荐
分类导航