Javascript 陣列的稀疏性質
在Javascript 中,陣列本質上是稀疏的,這意味著它們不會自動為0 之間的所有元素分配記憶體和目前索引。相反,元素僅在存取或分配時才分配。
例如,考慮以下程式碼,其中我們將當前時間的元素設定為索引:
array[Date.getTime()] = value;
相反正如您所期望的,這不會導致解釋器分配從0 到當前時刻的所有元素。相反,它只分配訪問的特定元素。
雜湊表實作
Javascript 陣列在內部實作為雜湊表。這意味著鍵(索引)不僅可以是整數,還可以是字串、浮點數或物件。插入哈希表後,所有鍵都會使用 toString() 方法轉換為字串。
驗證碼
您可以透過以下測試驗證此稀疏性質程式碼:
var array = []; array[0] = "zero"; array[new Date().getTime()] = "now"; array[3.14] = "pi"; for (var i in array) { console.log("array[" + i + "] = " + array[i] + ", typeof(" + i + ") == " + typeof(i)); }
此程式碼迭代實際定義的索引和輸出:
array[0] = zero, typeof(0) == string array[1254503972355] = now, typeof(1254503972355) == string array[3.14] = pi, typeof(3.14) == string
這表明非整數索引也可以在不分配中間元素的情況下工作。但是,請注意,使用 i 範圍從 0 到 array.length 的傳統 for 迴圈可能會導致非標準陣列索引問題。
以上是JavaScript 陣列是真正密集的,還是表現出稀疏行為?的詳細內容。更多資訊請關注PHP中文網其他相關文章!