Javascript的内存释放实验

来源:互联网 发布:爱奇艺旧版软件源 编辑:程序博客网 时间:2024/05/01 09:31

http://topic.csdn.net/t/20021210/13/1247117.html

 

http://topic.csdn.net/u/20070501/09/eeb7bb7b-ebe9-432d-a496-87a645e75cfd.html

 

有很多人提到IE下使用AJAX内存会增长很快.

我稍微研究了一下   发现其实IE的并不会主动的对未引用的变量进行回收
CollectGarbage()只是对值为null的变量进行回收,其实就算不用CollectGarbage()在下次分配内存的时候IE也会对null的内存进行重新分配.

例如一个有类   class1
function   class1()
{
this.a   =    "xxxx ";
this.b   =    "xxxx ";
this.c   =    "xxxx ";
this.d   =    "xxxx ";
}

var   aa   =   new   class1();
aa   =   null;
这样被释放的内存也只有aa这个变量.   
class1的实例的所有成员的内存完全没有被释放,这些内存将在IE最小化的时候才会被废弃.

也就是说我们需要手动的对这些内存进行释放.
var   aa   =   new   class1();
for(o   in   aa)aa[o]=null;
aa   =   null;
这样就可以完全把class1的内存释放掉

但如果class1里面还有一个类的实例
function   class1()
{
this.a   =    "xxxx ";
this.b   =    "xxxx ";
this.c   =    "xxxx ";
this.d   =   new   class2();
}
function   class2()
{
this.a   =    "xxxx ";
this.b   =    "xxxx ";
this.c   =    "xxxx ";
this.d   =    "xxxx ";
}

var   aa   =   new   class1();
for(o   in   aa)aa[o]=null;
aa   =   null;

同理这样释放内存的话   class1里面的class2的内存就没有被释放
至于怎么释放我就不多说了

对于document.createElement()方法
其实就相当于是一个新的DHTMLElement实例   稍微估算了一下一般是8K一个

以下是重点
IE在移除一个HTML元素时   只是对所有属性进行了回收   而所有的事件完全没有被回收
而这些事件方法往往是内存占用的大鳄.通常导致DHTML元素8K的内存完全没有被回收

例如:
function   class1()
{
this.a   =    "xxxx ";
this.b   =    "xxxx ";
this.c   =    "xxxx ";
this.d   =    "xxxx ";
this.e   =   document.createElement( "div ");
this.e.onclick   =   function(){.....;}
this.e.ondblclick   =   function(){.....;}
}

var   aa   =   new   class1();
for(o   in   aa)aa[o]=null;
aa   =   null;

这样的话就平白无故的多了8K无法回收的内存

对于上面的情况我们需要这样   才能回收

var   aa   =   new   class1();
aa.e.onclick   =   null;
aa.e.ondblclick   =   null;
for(o   in   aa)aa[o]=null;
aa   =   null;

当然也有个通用的回收方法   效率很低而已
var   aa   =   new   class1();
for(o   in   aa.e)
             if(o.indexOf( "on ")==0)
                         aa.e[o]=null;
for(o   in   aa)
             aa[o]=null;
aa   =   null;

总结以上   IE的内存不会被自动回收   但不是不能被回收
怎么回收   那就要靠你自己动手来写了

原创粉丝点击