<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • Javascript垃圾收集機制介紹

    時間:2024-09-08 04:34:20 JavaScript 我要投稿
    • 相關(guān)推薦

    Javascript垃圾收集機制介紹

      經(jīng)常使用 Javascript 的人會琢磨其垃圾收集機制,Javascript 并不像 C,C++ 那樣需要開發(fā)者手動去清除垃圾,在編寫 Javascript 程序是,開發(fā)者無需關(guān)心內(nèi)存使用問題,所需內(nèi)存分配以及無用內(nèi)存(垃圾)的回收完全實現(xiàn)了自動管理。究其根源,主要是程序收集那些不再使用的變量,并且釋放其占用的內(nèi)存。因此,垃圾收集機制會按照固定時間間隔,周期性反復(fù)的執(zhí)行這一操作。

    Javascript垃圾收集機制介紹

      舉例來說,局部變量只存在于函數(shù)內(nèi)部,程序會為局部變量在棧內(nèi)存或堆內(nèi)存中分配對應(yīng)的存儲空間,當函數(shù)運行結(jié)束,局部變量所占用的內(nèi)存就沒有存在的必要了,這時程序會釋放局部變量所占用的內(nèi)存供其他變量使用。這是程序最簡單釋放內(nèi)存的方法,但是很多時候,程序中變量會一直被使用,此時垃圾收集機制必須跟蹤變量并且判斷其是否被使用,是否可以釋放其內(nèi)存空間。

      垃圾收集機制主要判斷變量釋放內(nèi)存空間的方法有兩個:其一是標記清除法,其二是引用計數(shù)法。

      一、標記法,每個變量都有其運行環(huán)境,變量創(chuàng)建后會在某種環(huán)境中運行,比如創(chuàng)建一個局部變量,局部變量會運行在函數(shù)體內(nèi)。當函數(shù)運行時,會標記局部變量為“進入環(huán)境”,當函數(shù)體運行結(jié)束后,意味著變量脫離了其運行環(huán)境,此時則將變量標記為“離開環(huán)境”。對于“離開環(huán)境”的變量,垃圾收集機制會進行相應(yīng)記錄,并且在下一個回收周期時將其釋放。

      二、引用計數(shù)法,跟蹤記錄每個值的被引用次數(shù)。聲明一個變量并將一個引用類型值賦給該變量時,這個值得引用次數(shù)就是 1。如果同一個值又被賦給另外一個變量,則該值的引用次數(shù)加 1。相反,如果包含對這個值的引用的變量又取得另外一個值,這個值得引用次數(shù)減 1。當這個值得引用次數(shù)為 0 時,則說明沒有辦法再訪問到此值,因此就可以將其占用的內(nèi)存空間回收。當垃圾收集器在下一個周期運行時,會釋放引用次數(shù)為零的值所占用的內(nèi)存空間。(原文解釋參考:Javascript 高級程序設(shè)計 - 第二版)

      舉個例子來說:

      復(fù)制代碼 代碼如下:

      function countMethod(){

      var object1 = new Object(); // 聲明變量,計數(shù)器由 0 變?yōu)?1

      var object2 = new Object(); // 聲明變量,計數(shù)器由 0 變?yōu)?1

      object1.method1 = object2; // object1 計數(shù)器 -1,object2 計數(shù)器 +1

      object2.method2 = object1; // object1 計數(shù)器 +1,object2 計數(shù)器 -1

      }

      此函數(shù)運行退出后,object1 的計數(shù)器讀數(shù)為 1,object2 的計數(shù)器度數(shù)為 1。所以兩個變量都不會被銷毀。如果大量的這樣的程序存在于函數(shù)體內(nèi),就會導(dǎo)致大量的內(nèi)存被浪費而無法回收,從而導(dǎo)致內(nèi)存的泄露。

      上述問題解決方法,手動釋放 object1 object2 所占用的內(nèi)存。即:

      復(fù)制代碼 代碼如下:

      object1.method1 = null;

      object2.method2 = null;

      對比上面的例子,舉一個正常情況下的例子。

      復(fù)制代碼 代碼如下:

      function countMethod(){

      var object1 = new Object(); // 聲明變量,計數(shù)器由 0 變?yōu)?1

      var object2 = new Object(); // 聲明變量,計數(shù)器由 0 變?yōu)?1

      object1.method1 = "This is object1"; // object1 計數(shù)器 -1,object1 讀數(shù)變?yōu)?

      object2.method2 = "This is object2"; // object2 計數(shù)器 -1,object2 讀數(shù)變?yōu)?}

      通過上例看出,正常情況下,當函數(shù)運行結(jié)束后,object1 object2的讀數(shù)均為 0,在下一個垃圾收集周期時,會被回收并且釋放其所占用的內(nèi)存。

    【Javascript垃圾收集機制介紹】相關(guān)文章:

    perl- javascript中class的機制05-03

    JavaScript數(shù)組常用方法介紹09-04

    javascript克隆對象深度介紹07-25

    對javascript的理解08-08

    JAVA垃圾收集算法與內(nèi)存泄露的解決方法12-04

    常用的JavaScript模式09-22

    Javascript的this用法簡述08-15

    有關(guān)深入理解JavaScript中的并行處理的介紹10-14

    JavaScript學習筆記08-24

    JavaScript 基礎(chǔ)教學09-29

    主站蜘蛛池模板: 精品无码人妻一区二区三区不卡| 精品无码久久久久久久久久| 成人精品一区二区三区免费看| 中日韩产精品1卡二卡三卡| 2022国产精品最新在线| 国产精品丝袜一区二区三区| 精品久久久久久国产免费了| 国产偷亚洲偷欧美偷精品| 无码人妻精品一区二区三区久久 | 中文字幕九七精品乱码| 国产精品亚洲美女久久久| 久久久国产精品福利免费| 无码人妻丰满熟妇精品区| 久久夜色精品国产| 国产成人精品一区在线| 久久精品国产只有精品2020| 国产成人精品999在线观看| 日韩精品久久无码中文字幕| 久久精品18| 精品国产日韩亚洲一区| 97久人人做人人妻人人玩精品| 999久久久免费精品国产| 97精品一区二区视频在线观看| 精品福利一区二区三区免费视频| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 国产精品成人在线| 国产精品亚洲аv无码播放| 久久精品无码一区二区无码 | 国产成人精品日本亚洲18图| 无码日韩人妻精品久久蜜桃 | 色婷婷久久久SWAG精品| 久久精品国产第一区二区| 国产精品亚洲欧美大片在线观看 | 99热成人精品免费久久| 91国内揄拍国内精品情侣对白| 99精品电影一区二区免费看| 午夜精品美女写真福利| 午夜精品视频在线| 国产成人1024精品免费 | 91精品国产人成网站| 国产精品久久久久乳精品爆|