DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> js函數的引用, 關於內存的開銷
js函數的引用, 關於內存的開銷
編輯:關於JavaScript     
請看如下代碼:
復制代碼 代碼如下:
var arr = [];
var cc = function(){alert('xx');};


for(var i = 0; i<2; i++){

arr[i] = function(){alert('yy');}
arr[i+10] = cc;
}

console.group('開始')
console.group('1')
console.info( arr[0] == arr[1]);
console.info( arr[0] === arr[1]);

console.info( arr[0].toString());
console.info( arr[1].toString());
console.groupEnd('1')


console.group('2')
console.info( arr[10] == arr[11]);
console.info( arr[10] === arr[11]);

console.info( arr[10].toString());
console.info( arr[11].toString());
console.group()
console.groupEnd('開始');


在火狐的firebug中的控制台運行結果如下圖:




分析:

第五行代碼的循環開始,循環結束後 arr數組得到的結果為:
arr[0] = function(){ alert('yy'); }
arr[1] = function(){ alert('yy'); }
arr[10] = cc
arr[11] = cc
可以看出來, 控制台進行結果,上圖。
arr[0] 不等於 arr[1]
但是 arr[10] 等於 arr[11] , 因為它引用了前面定義的變量。
其實在循環的過程中都在重新定義函數function(){alert('yy');}
arr[0] 和 arr[1]的toString 輸出的內容是相同的。 但是兩個是獨立的方法, 占用各自的內存,所以為了省內存, 可以用於把函數定義在循環外。
函數定義在循環外面的前提條件是,函數沒有接受在循環內變化的變量。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved