お世話になります。クロージャ使用によるメモリリークについて、
function doHoge(element) {
element.onClick = function() {
// do domething
}
}
でメモリリークが起こりますが、次の場合はどうなるでしょうか。
function doHoge() {
var element = document.getElementById("aa");
element.onClick = function() {
// do domething
}
}
あるサイトではdoHogeの引数のみに言及していましたが、この場合もクロージャはelementを参照するのでメモリリークが起こると思うのですが、
どうでしょうか。
よろしくお願いします。
No.2ベストアンサー
- 回答日時:
[IEのメモリリーク - zorioの日記]
http://d.hatena.ne.jp/zorio/20060316/1142528060
↑によるとActivationオブジェクト経由で循環参照してしまうみたいですね。
たぶんこれで回避できる?
[IE6のメモリリークを華麗に回避 - zorioの日記]
http://d.hatena.ne.jp/zorio/20080609/1213028969
でもIEのメモリリークはもう直っているという話もある。
[IEのメモリリークが直ってるっぽい。 - zorioの日記]
http://d.hatena.ne.jp/zorio/20070626/1182875782
条件によってはやっぱりだめみたいですが。
[やっぱりIEのメモリリークは直ってなかった - zorioの日記]
http://d.hatena.ne.jp/zorio/20070918/1190135017
ありがとうございます。リンク先拝見しました。
どうもメモリリークの原因は私が思っていたより複雑なようですね。
解決策もいちいちしてたらちょっと手間がかかりそうです。
No.1
- 回答日時:
IEの問題ですよね? でしたらこちらが詳しいです。
http://nanto.asablo.jp/blog/2005/12/04/165848
==引用==
なお、一見メモリリークを引き起こしそうだが実はそうでないパターンもある。以下の例がそうだ。
function addActions()
{
var links = document.getElementsByTagName("a");
for (var i = 0; i < links.length; i++)
links[i].onclick = function () { alert("Hello!"); };
}
クロージャが a 要素全体への参照を持っているように思えるが、links の内容は動的 (あとから a 要素が追加 / 削除された場合、それは links にも反映される) であり、links が直接特定の a 要素への参照を持っているわけではないので循環参照にはならないと考えられる。
==引用ここまで==
どうやらその場合は大丈夫そうです。
回答ありがとうございます。
そのサイトも見ましたが、それは今回のパターンとは違うものではないでしょうか。
> links が直接特定の a 要素への参照を持っているわけではない
とありますが、
var element = document.getElementById("aa");
element.onClick = function() {
}
の場合はelementが直接特定の要素への参照を持ってしまっています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript コードレビューをお願いします。 1 2022/07/16 05:38
- その他(プログラミング・Web制作) pythonでのカーソル移動がずれる 2 2023/07/30 08:51
- JavaScript 1日1回引けるJavaScriptおみくじについて 1 2022/12/12 22:28
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- JavaScript 変数のスコープの問題? 3 2022/06/23 09:32
- JavaScript スマフォではボタンを表示させたくない 2 2023/01/20 14:26
- JavaScript gasについて 1 2022/05/31 21:51
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/07 21:04
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- 統計学 確率論と統計学の{補事象(complementary element)}の読み方は ほじしょう でし 3 2022/10/10 23:48
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
関数でy=g(x)のgとは何の略です...
-
関数名をテキストから読み込む...
-
JAVAスクリプトで指定時間以降...
-
ユーザ関数で引数省略は可能で...
-
functionから別のfunctionを実...
-
ページ内に複数表がある場合のT...
-
idを使わずにonclickで自身の要...
-
(function(){})()の意味
-
Linux バイナリ実行できない "...
-
ボタンをクリックすると数が増...
-
同じIDで定義した要素の配列を...
-
C#テキストボックスの文字を配...
-
ワイルドカード もしくは あ...
-
window.openでタイトル名の指定
-
テキストボックスに文字列やタ...
-
javascript 変数名の連結をしたい
-
イラレでナンバリングする方法
-
翌月を取得するGASが分かりません
-
google apps scriptの終了のさせ方
-
JavaScriptで決まった「時刻」...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
idを使わずにonclickで自身の要...
-
functionから別のfunctionを実...
-
関数でy=g(x)のgとは何の略です...
-
jslintのエラーについて質問
-
クリックすると上に開くアコー...
-
XMLHttpRequestでキャッシュを...
-
ajax反映後のjqueryが動かない
-
要素名がスペースを含む場合のj...
-
function(e)の意味を教えてくだ...
-
jQueryの :not() .not() が有効...
-
jQueryでzipを解凍読み込みする...
-
getElementByIdを使用したグロ...
-
関数名をテキストから読み込む...
-
jqueryuiのdialog
-
addEventListener()でリスナー...
-
jqueryのグローバル変数とロー...
-
jQuery 同じ処理を関数にまとめ...
-
drawImageの描画順序の指定につ...
-
XMLHttpRequestオブジェクトが...
-
jQueryが読み込めない
おすすめ情報