欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

簡單談?wù)刯avascript中的變量、作用域和內(nèi)存問題

 更新時間:2015年08月30日 09:45:29   投稿:hebedich  
這篇文章主要介紹了簡單談?wù)刯avascript中的變量、作用域和內(nèi)存問題的相關(guān)資料,需要的朋友可以參考下

【變量】

[1]定義:可變的量,相當于給一個不定的數(shù)據(jù)起了一個外號。變量是存儲信息的容器。
[2]特性:js中的變量是松散類型的,可以保存任何類型的數(shù)據(jù)。它只是在特定時間用于保存特定值的一個名字而已。由于不存在定義某個變量必須要保存何種數(shù)據(jù)類型值的規(guī)則,變量的值及其數(shù)據(jù)類型可以在腳本的生命周期內(nèi)改變。
[3]變量聲明:變量可以在聲明時賦值,但不能有其他操作,如+=、-=等

var a = 2;//是正確的
var a += 2;//是錯誤的
var a = 2++;//是錯誤的,++只能用于變量,不能用于常量

[4]注意:用var操作符定義的變量將成為定義該變量的作用域中的局部變量。若省略var操作符,可以創(chuàng)建一個全局變量,但在嚴格模式下會拋出 ReferenceError錯誤

[5]var:使用var聲明的變量會自動被添加到最接近的環(huán)境中。如果初始化變量時沒有使用var聲明,該變量會自動被添加到全局環(huán)境。在嚴格模式下,初始化未經(jīng)聲明的變量會導(dǎo)致錯誤。
[6]局部變量:如果局部環(huán)境中存在同名標識符,就不會使用位于父環(huán)境中的標識符。任何位于局部變量color的聲明之后的代碼,如果不使用window.color都無法訪問全局color變量

【標識符】

[1]定義:變量、函數(shù)、屬性的名字,或者函數(shù)的參數(shù)。
[2]注意:
  [2.1]第一個字符必須是一個字母、下劃線或一個美元符號。其他字符可以是字母、下劃線、美元符號或數(shù)字[不能出現(xiàn)中劃線]
  [2.2]標識符中的字母也可以包括拓展的ASCII或Unicode字母字符,可以使用中文
  [2.3]標識符應(yīng)采用小駝峰格式,第一位應(yīng)該是數(shù)據(jù)的類型,常見的標識如下:

    數(shù)組     a   Array aItems
    布爾值    b   Boolean bIsComplete
    浮點數(shù)    f    FLoat fPrice
    函數(shù)     fn   Function fnHandler
    整數(shù)     i    Integer iItemCount
    對象     o   Object oDIv1
    正則表達式  re   RegExp reEmailCheck
    字符串     s    String sUserName
    變量     v   Variant vAnything 

  [2.4]不能把關(guān)鍵字、保留字、true、false和null用作標識符
  [2.5]對于不符合標識符命名規(guī)則的屬性如background-color應(yīng)寫為大括號方式[backgroundColor]
[3]標識符解析:標識符解析是沿著作用域鏈一級一級地搜索標識符的過程。搜索過程始終從作用域鏈的前端開始,然后逐級地向后回溯,直到找到標識符為止(如果找不到標識符,表示標識符尚未聲明,通常會導(dǎo)致錯誤發(fā)生)。
  [3.1]如果局部環(huán)境中存在著同名標識符,就不會使用父環(huán)境中的標識符
    e.g. 全局和局部有同名標識符color,任何位于局部變量color的聲明之后的代碼,如果不使用window.color都無法訪問全局color變量
  [3.2]JavaScript引擎在優(yōu)化標識符查詢方面做得不錯,訪問全局變量和局部變量的時間差別可以忽略不計

【作用域】(也稱為執(zhí)行環(huán)境)

  [注意]javascript中沒有塊級作用域 
[1]執(zhí)行環(huán)境:執(zhí)行環(huán)境定義了變量或函數(shù)有權(quán)訪問的其他數(shù)據(jù),決定了它們各自的行為。每個執(zhí)行環(huán)境都有一個與之相關(guān)聯(lián)的變量對象。環(huán)境中定義的所有變量和函數(shù)都保存在這個對象中。

[2]全局執(zhí)行環(huán)境:
  [2.1]全局執(zhí)行環(huán)境是最外圍的一個執(zhí)行環(huán)境,在web瀏覽器中,全局執(zhí)行環(huán)境被認為是window對象。因此所有全局變量和函數(shù)都是作為window對象的屬性和方法創(chuàng)建的。全局執(zhí)行環(huán)境直到應(yīng)用程序退出例如關(guān)閉網(wǎng)頁或瀏覽器時才會被銷毀
  [2.2]一個頁面就相當于一個全局作用域。不論是頁面中的js代碼,還是引用的外部js文件,最終都會按照在頁面中的先后依次解析。

[3]函數(shù)執(zhí)行環(huán)境:每個函數(shù)都有自己的執(zhí)行環(huán)境,當執(zhí)行流進入一個函數(shù)時,函數(shù)的環(huán)境就會被推入一個環(huán)境棧中,而在函數(shù)執(zhí)行之后,棧將其環(huán)境彈出,把控制權(quán)返回給之前的執(zhí)行環(huán)境。

[4]作用域鏈:當代碼在一個環(huán)境中執(zhí)行時,會創(chuàng)建變量對象的一個作用域鏈。作用域鏈的作用是保證對執(zhí)行環(huán)境有權(quán)訪問的所有變量和函數(shù)的有序訪問。作用域的前端始終都是當前執(zhí)行的代碼所在環(huán)境的變量對象。如果這個環(huán)境是函數(shù),則將其活動對象作為變量對象?;顒訉ο笤谧铋_始時只包含一個變量,即arguments對象(這個對象在全局環(huán)境中是不存在的)。作用域鏈中的下一個變量對象來自包含環(huán)境,而再下一個變量對象則來自下一個包含環(huán)境。這樣,一直延續(xù)到全局執(zhí)行環(huán)境;全局執(zhí)行環(huán)境的變量對象始終都是作用域鏈中的最后一個對象。

  [4.1]作用域鏈的特點:內(nèi)部環(huán)境可以通過作用域鏈訪問所有的外部環(huán)境,但外部環(huán)境不能訪問內(nèi)部環(huán)境中的任何變量和函數(shù)。這些環(huán)境之間的聯(lián)系是線性、有次序的。每個環(huán)境都可以向上搜索作用域鏈,以查詢變量和函數(shù)名;但任何環(huán)境都不能通過向下搜索作用域鏈而進入另一個執(zhí)行環(huán)境。

[5]延長作用域鏈:

  [5.1]try-catch語句:catch塊會創(chuàng)建一個新的變量對象,其中包含的是被拋出的錯誤對象的聲明
  [5.2]with語句:會將指定的對象添加到作用域鏈中

function buildUrl(){
  var qs = '?debug=true';
  with(location){
    var url = href + qs;
  }
  return url;
}

【垃圾回收】:javascript具有自動垃圾收集機制,執(zhí)行環(huán)境會負責管理代碼執(zhí)行過程中使用的內(nèi)存。

[1]垃圾回收機制:找出那些不再繼續(xù)使用的變量,然后釋放其占用的內(nèi)存,垃圾收集器會按照固定的時間間隔,或代碼執(zhí)行中預(yù)定的收集時間,周期性地執(zhí)行這一操作

[2]垃圾收集標記無用變量的兩種策略

  [2.1]標記清除,標記“進入環(huán)境”和“離開環(huán)境”。離開作用域的值將被自動標記為可以回收,因此將在垃圾收集期間被刪除
  [2.2]引用計數(shù),跟蹤記錄每個值被引用的次數(shù)。當聲明了一個變量并將一個引用類型值賦給該變量時,則這個值的引用次數(shù)就是1,如果同一個值又被賦給另一個變量,則該值的引用次數(shù)加1,相反,如果包含對這個值的引用的變量又取得了另外一個值,則這個值的引用次數(shù)減1,當這個值的引用次數(shù)為0時,則說明沒有辦法再訪問這個值了,因此就可以將其占用的內(nèi)存空間回收回來。
    [2.2.1]引用計數(shù)的問題:循環(huán)引用:對象A中包含一個指向?qū)ο驜的指針,對象B中也包含一個指向?qū)ο驛的指針
    [2.2.2]IE:IE中有一部分對象并不是原生js對象,例如,其BOM和DOM中的對象就是使用c++以COM對象的形式實現(xiàn),而COM對象的垃圾回收機制采用的就是引用計數(shù)策略

var element = document.getElementById('some_element');
var myObject = new Object();
myObject.element = element;
element.someObject = myObject;

    解決辦法:為了避免類似這樣的循環(huán)引用,最好是在不使用它們的時候手工斷開

myObject.element = null;
element.someObject = null;   
    為了解決此問題,IE9把BOM和DOM對象都轉(zhuǎn)換成了真正的js對象

【內(nèi)存管理】

[1]主要問題:分配給web瀏覽器的可用內(nèi)存數(shù)量通常要比分配給桌面應(yīng)用程序的少,目的是防止運行js的網(wǎng)頁耗盡全部系統(tǒng)內(nèi)存而導(dǎo)致系統(tǒng)崩潰。內(nèi)在限制問題不僅會影響給變量分配內(nèi)存,同時還會影響調(diào)用棧以及在一個線程中能夠同時執(zhí)行的語句數(shù)量 

[2]優(yōu)化方式:為執(zhí)行中的代碼只保存必要的數(shù)據(jù)。一旦數(shù)據(jù)不再有用,最好通過將其值設(shè)置為null來釋放其引用,這種做法叫解除引用。這一做法適用于大多數(shù)全局變量和全局對象的屬性以及循環(huán)引用變量,局部變量會在它們離開執(zhí)行環(huán)境時自動被解除引用。

解除變量的引用并不意味著自動回收該值所占用的內(nèi)存。解除引用的真正作用是讓值脫離執(zhí)行環(huán)境,以便垃圾收集器下次運行時將其回收。

相關(guān)文章

最新評論