JavaScript中的索引陣列、關聯陣列和靜態陣列、動態陣列的分類講

才智咖 人氣:1.03W

陣列分類:

JavaScript中的索引陣列、關聯陣列和靜態陣列、動態陣列的分類講

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為基礎的,這裡說動態陣列是廣義的,不管採用什麼方式實現。

Listary2 = new ArrayList();

(1);//可以動態的'新增元素,陣列的長度也隨著變化

(3);

(6);

複製程式碼 程式碼如下:

/* js的陣列屬於動態陣列 */

var ary = [];//定義一個數組,未指定長度

ary[0] = 1;//可以動態的新增元素

(3);

(5);

alert((","));//輸出1,3,5

js的陣列同時屬於索引陣列和動態陣列,因為本質上它就是一個js物件,體現著js動態語言特性。但js的索引陣列並非“連續分配”記憶體的,因此索引方式並不會帶來很高的效率。而java中的陣列則是連續分配記憶體的。

最近更新