六月丁香五月婷婷,丁香五月婷婷网,欧美激情网站,日本护士xxxx,禁止18岁天天操夜夜操,18岁禁止1000免费,国产福利无码一区色费

學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 電腦硬件知識(shí) > 內(nèi)存知識(shí) > IE6內(nèi)存泄漏怎么解決

IE6內(nèi)存泄漏怎么解決

時(shí)間: 孫勝龍652 分享

IE6內(nèi)存泄漏怎么解決

  大家都知道,內(nèi)存是電腦必不可少的一個(gè)硬件,所以說(shuō),關(guān)于內(nèi)存會(huì)有各種各樣的問(wèn)題,學(xué)習(xí)啦小編就在這里給大家介紹IE6內(nèi)存泄漏怎么解決。

  Hedger Wang 在國(guó)內(nèi) blog 上得到的方法:使用 try … finally 結(jié)構(gòu)來(lái)使對(duì)象最終為 null ,以阻止內(nèi)存泄露。

  其中舉了個(gè)例子:

  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....

  對(duì)于 IE6 中,引起內(nèi)存泄露的原因,可看《Understanding and Solving Internet Explorer Leak Patterns》一文。

  上面的例子,應(yīng)該屬于上文中的 “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....

  可能大家有疑問(wèn): finally 是如何解析的呢?

  答案是:先執(zhí)行 try 語(yǔ)句再執(zhí)行 finally 語(yǔ)句。

  例如:

  function foo() {

  var x = 0;

  try {

  return print("call return " ( x));

  } finally {

  print("call finally " ( x));

  }

  }

  print('before');

  print(foo());

  print('after');

  返回的結(jié)果為:

  print » before

  print » call return 1

  print » call finally 2

  print » true

  print » after

297648