当前位置: 首页 > 图文教程 > 工具软件 > 浏览下载 > IE6内存泄露的另类解决方法

浏览下载
影响网际快车(FlashGet)下载速度的5个小动作
IE8兼容性视图解决网站不兼容页面显示错乱
打开浏览器速度缓慢的原因分析
QQ旋风不可不知的实用下载技巧
浏览器大战的今天 你选择哪个浏览器
迅雷下载技巧:缓存设置和监视剪贴板
Firefox 3.6 RC1最新版本测试满足你的期待
2010年浏览器将更加关注最基础的使用体验
最常见的浏览器(IE,火狐)到底哪个好用
推荐阅读长长见识:你没有听说过的10种浏览器
初学者入门:在线视频怎么下载?
用傲游浏览器上淘宝网的简单攻略
评测:国内知名软件下载网站的广告推广
金山网盾:IE极光0day漏洞利用色情网站挂马
UC浏览器里任意复制粘贴文本的方法
火狐中国版2010个别新功能噱头大用途小
评测报告:搜狗浏览器2.0和傲游浏览器2.5
一起来体验火狐3.6最新最酷的功能
使用傲游浏览器获取和组织资讯的方法
优化IE 8使用性能的四个建议

浏览下载 中的 IE6内存泄露的另类解决方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-11   浏览: 65 ::
收藏到网摘: n/a

Hedger Wang 在国内 blog 上得到的方法:使用 try … finally 结构来使对象最终为 null ,以阻止内存泄露。

其中举了个例子:

function createButton() {
    var obj = document.createElement("button");
    obj.innerHTML = "click me";
    obj.onclick = function() {
        //handle onclick
    }
    obj.onmouseover = function() {
        //handle onmouseover
    }
    return obj;//return a object which has memory leak problem in IE6
}
var dButton = document.getElementById("d1").appendChild(createButton());
//skipped.... 

对于 IE6 中,引起内存泄露的原因,可看《Understanding and Solving Internet Explorer Leak Patterns》一文。

上面的例子,应该属于上文中的 “Closures”原因。

再看下用 try … finally 的解决方法:

/**
     * Use the try ... finally statement to resolve the memory leak issue
*/
function createButton() {
    var obj = document.createElement("button");
    obj.innerHTML = "click me";
    obj.onclick = function() {
        //handle onclick
    }
    obj.onmouseover = function() {
        //handle onmouseover
    }
    //this helps to fix the memory leak issue
    try {
        return obj;
    } finally {
        obj = null;
    }
}
var dButton = document.getElementById("d1").appendChild(createButton());
//skipped....

可能大家有疑问: finally 是如何解析的呢?

答案是:先执行 try 语句再执行 finally 语句。

例如:

function foo() {
    var x = 0;
    try {
        return print("call return " + (++x));
    } finally {
        print("call finally " + (++x));
    }
}
print('before');
print(foo());
print('after');

返回的结果为:
print » before
print » call return 1
print » call finally 2
print » true
print » after

更多详细的演示:
《Finally, the alternative fix for IE6’s memory leak is available》

相关的一些讨论:
《Is “finally” the answer to all IE6 memory leak issues?》