陣列分類:
1、從陣列的下標分為索引數組、關聯數組
/* 索引數組,即通常情況下所說的數組 */
var ary1 = [1,3,5,8];
//依索引去取數組元素,從0開始(當然某些語言實作從1開始)
//索引其實就是序數,一個整數數字
alert(ary1[0]);
alert(ary1[1]);
alert(ary1[2]);
alert(ary1[3]);
/* 關聯數組,指以非序數組類型為下標來存取的數組 python中稱為字典 */
var ary2 = {};
//訪問時,以非序數(數字),這裡是字串
ary2["one"] = 1;
ary2["two"] = 2;
ary2["thr"] = 3;
ary2["fou"] = 4;
2、從資料的儲存分為靜態陣列、動態陣列
// java中的靜態陣列
// 定義後數組的長度固定了不能改變,依索引取數組元素
Int[] ary1 = {1,3,6,9};
// java中的動態數組
// java中的ArrayList實作是以Array為基礎的,這裡說動態陣列是廣義的,不管採用什麼方式實作。
List ary2 = new ArrayList();
ary2.add(1);//可以動態的添加元素,數組的長度也隨著變化
ary2.add(3);
ary2.add(6);
/* js的陣列屬於動態陣列 */
var ary = [];//定義一個數組,未指定長度
ary[0] = 1;//可以動態的添加元素
ary.push(3);
ary.push(5);
alert(ary.join(","));//輸出1,3,5
js的數組同時屬於索引數組和動態數組,因為本質上它就是一個js對象,體現著js動態語言特性。但js的索引數組並非「連續分配」記憶體的,因此索引方式並不會帶來很高的效率。而java中的數組則是連續分配記憶體的。