ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript によって引き起こされるメモリ リーク

JavaScript によって引き起こされるメモリ リーク

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-05-16 18:21:441267ブラウズ

検証するために、メモリリークを検証するページを作成しました。コードは次のとおりです:

コードをコピー コードは次のとおりです:

="http://www.w3.org/1999/xhtml">


メモリ リークのテスト

>


要素の作成
[br]
< ;a href='javascript:removeDiv();'>要素を削除

[br]
DIV はまだ存在します









メモリ リークのテスト
を実行するために更新する必要があります]
「要素の作成」をクリックしてから、「要素の削除」をクリックして、removeChild を使用して新しく作成した要素を削除し、「DIV がまだ存在するかどうかをテスト」をクリックして、要素が本当に削除されたかどうかを確認します。結果のアラートに が表示されます。ヌル。本当に要素ノードが削除されたようです。では、Situ Zhengmei の記事で言及されているメモリ リークとは何でしょうか?私も Google で検索して、removeChild によるメモリ リークの問題に遭遇した人がいるかどうかを確認する必要がありました。最後に、msdn の英語版で同じ質問をしている人 (リンク) を見つけたので、その中のコードを少し変更して、removeChild によって引き起こされるメモリ リークを比較して確認しました。 コードは次のとおりです:




コードをコピーします


コードは次のとおりです:



测试 removeChild 导致的内存泄漏


产生内存泄漏方式


不产生内存泄漏方式


<script> <BR>var dialog; <BR>function add() <BR>{ <BR>dialog = document.createElement('div'); <BR>var html = '<div><p>Title</script>
';
dialog.innerHTML = html;
document.body.appendChild(dialog);
dialog.style.marginTop='200px';
dialog.style.marginLeft='200px';
}
function remove()
{
document.body.removeChild(dialog);
dialog=null;
}
function leak()
{
for(var i=0;iadd();
remove();
}
alert('leak done');
}
function notLeak()
{
for(var i=0;iadd();
discardElement(dialog);
}
alert('notLeak done');
}
function discardElement(element) {
var garbageBin = document.getElementById('IELeakGarbageBin');
if (!garbageBin) {
garbageBin = document.createElement('DIV');
garbageBin.id = 'IELeakGarbageBin';
garbageBin.style.display = 'none';
document.body.appendChild(garbageBin);
}
// move the element to the garbage bin
garbageBin.appendChild(element);
garbageBin.innerHTML = '';
}


'; dialog.innerHTML = html; document.body.appendChild(dialog); dialog.style.marginTop='200px'; dialog.style.marginLeft='200px'; } function remove() { document.body.removeChild(dialog); dialog=null; } function leak() { for(var i=0;i
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
首先运行“产生内存泄漏方式”
未运行前打开任务管理器监控内存大小如下:

运行完再查看内存大小,可以看到内存大小已经增加了很多。

接着我再运行“不产生内存泄漏方式”
未运行前打开任务管理器监控内存大小如下:

运行完再查看内存大小,可以看到内存较“产生内存泄漏方式”小了很多。

PS: 为了检验 removeChild 导致的内存泄漏 ,我 google 了很多 IE 内存泄漏的相关文章。
相关文章如下:
http://www.cnblogs.com/dwjaissk/archive/2007/07/20/824884.html
http://bugs.dojotoolkit.org/ticket/1727
http://article.yeeyan.org/view/3407/10103
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。