IE8 内存一直增长 内存泄露

最近开发的时候对页面使用了定时的局部更新,结果在ie6,7和Firefox下,一切正常,而在ie8下过上几个小时就浏览器就崩溃了,显示是内存溢出,我以为是代码写的不好导致内存泄露,但是ie6,7又正常,调查了一下,原来这是ie8的bug。 

问题点  

在IE8中,生成特定Dom节点所占用的内存是不会被释放的,即使这些节点被删除内存也不会被释放。 

内存泄露的节点类型包括:form、button、input、select、textarea、a、img和objec 

其他的大部分节点类型是不会泄露的,例如:span、div、p、table等等。 

此问题只发生在IE8,其他浏览器不发生。 

如果用户按了F5,IE8会重新刷新页面,首先它会unload window.top,这时候会释放掉内存。如果页面是iframe,则unload此iframe,没有任何反应。看起来只有window.top被 unload,内存才会被释放。 

例子  

例1 

执行下面的代码,IE8就会泄露内存。 

Javascript代码   收藏代码
  1. function leak1() {  
  2.     var node = document.getElementById("TO_AREA");  
  3.     node.innerHTML = "<img />";  
  4.     node.innerHTML = "";  
  5.     node = null;  
  6. }  


注意: 

* 此例子添加了节点,所以会泄露。 

* 在中有个div,id为“TO_AREA”。 

* 提醒一下,这里没有闭包和循环引用。 

例2 

下面的代码没有使用innerHTML,但是还是会泄露 

Javascript代码   收藏代码
  1. function leak2() {  
  2.     var node = document.getElementById("FROM_AREA").cloneNode(true);  
  3.     node.id = "NEW_AREA";  
  4.     document.body.appendChild(node);  
  5.     document.body.removeChild(node);  
  6.     node = null;  
  7. }  


注意: 

* FROM_AREA 是form的id,而且这里也没有闭包和循环引用。 
例3 

这是最简单,最直接的例子: 

Javascript代码   收藏代码
  1. function leak4() {  
  2.     var node = document.createElement("IMG");  
  3.     document.body.appendChild(node);  
  4.     document.body.removeChild(node);  
  5. }  


注意: 

* 如果用span来代替img,就不会有泄露了。 

这些例子只在IE8中泄露内存,我在Windows XP, Windows Vista, Windows Server 2008, Windows Server 2008 R2和Windows 7 中的IE8都作了测试,而且使用了IE8中的IE7兼容模式和标准模式,每种情况下都会泄露。 
测试页面 


关于泄露  

内存大小随着时间的推移而增长,但这并不直接导致浏览器崩溃。浏览器使用的内存好像是有上限的,它似乎会从某些内部手段来限制DHTML使用的内存。 

内存到达上限后,浏览器会自动处理,例如弹出对话框,显示内存不足。 


经过自己测试发现 IFrame同样存在这个问题(在IE8下)

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值