手机
当前位置:查字典教程网 >软件教程 >浏览下载 >IE6内存泄露的另类解决方法
IE6内存泄露的另类解决方法
摘要:HedgerWang在国内blog上得到的方法:使用try…finally结构来使对象最终为null,以阻止内存泄露。其中举了...

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”原因。

IE6内存泄露的另类解决方法1

再看下用 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?》

【IE6内存泄露的另类解决方法】相关文章:

谷歌chrome浏览器以图搜图的详细图文步骤

IE浏览器无法打开HTTPS的原因和解决办法

UC浏览器语音功能使用方法图解

360安全浏览器无痕浏览打开方法

IE浏览器菜单栏里面收藏夹为灰色点击不了的解决方法

IE浏览器下字体显示不正常的解决方法

火狐浏览器页面会显示错乱原因和解决方法

IE窗口变小和不能打开新窗口问题的解决

IE地址栏不显示网址的解决方法

IE7百度搜索搜索中文乱码问题的解决方法

精品推荐
分类导航