Java中數組的定義和使用教程(一)
數組的基本概念
如果說現在要求你定義100個整型變量,那麼如果按照之前的做法,可能現在定義的的結構如下:
int i1, i2, i3, ... i100;
但是這個時候如果按照此類方式定義就會非常麻煩,因為這些變量彼此之間沒有任何的關聯,也就是說如果現在突然再有一個要求,要求你輸出這100個變量的內容,意味著你要編寫System.out.println()語句100次。
其實所謂的數組指的就是一組相關類型的變量集合,並且這些變量可以按照統一的方式進行操作。數組本身屬於引用數據類型,那麼既然是引用數據類型,這裡面實際又會牽扯到內存分配,而數組的定義語法有如下兩類。
數組動態初始化:
聲明並開辟數組:
- 數據類型 [] 數組名稱 = new 數據類型[長度];
- 數據類型 [] 數組名稱 = new 數據類型[長度];
分佈進行數組空間開辟(實例化)
| Tables | Are |
| ————- |:————-?
| 聲明數組: | 數組類型 數組名稱[] = null; | | | 數組類型 [] 數組名稱 =null; | | 開辟數組空間: | 數組名稱 =new` 數組類型[長度]; |
那麼當數組開辟空間之後,就可以采用如下的方式的操作:
- 數組的訪問通過索引完成,即:“數組名稱[索引]”,但是需要註意的是,數組的索引從0開始,所以索引的范圍就是0 ~ 數組長度-1,例如開辟瞭3個空間的數組,所以可以使用的索引是:0,1,2,如果此時訪問的時候超過瞭數組的索引范圍,會產生java.lang.ArrayIndexOutOfBoundsException 異常信息;
- 當我們數組采用動態初始化開辟空間後,數組裡面的每一個元素都是該數組對應數據類型的默認值;
- 數組本身是一個有序的集合操作,所以對於數組的內容操作往往會采用循環的模式完成,數組是一個有限的數據集合,所以應該使用 for 循環。
- 在 Java 中提供有一種動態取得數組長度的方式:數組名稱.length;
范例: 定義一個int型數組
public class ArrayDemo { public static void main(String args[]) { int data[] = new int[3]; /*開辟瞭一個長度為3的數組*/ data[0] = 10; // 第一個元素 data[1] = 20; // 第二個元素 data[2] = 30; // 第三個元素 for(int x = 0; x < data.length; x++) { System.out.println(data[x]); //通過循環控制索引 } } }
數組本身除瞭聲明並開辟空間之外還有另外一種開辟模式。
范例: 采用分步的模式開辟數組空間
public class ArrayDemo { public static void main(String args[]) { int data[] = null; data = new int[3]; /*開辟瞭一個長度為3的數組*/ data[0] = 10; // 第一個元素 data[1] = 20; // 第二個元素 data[2] = 30; // 第三個元素 for(int x = 0; x < data.length; x++) { System.out.println(data[x]); //通過循環控制索引 } } }
但是千萬要記住,數組屬於引用數據類型,所以在數組使用之前一定要開辟控件(實例化),如果使用瞭沒有開辟空間的數組,則一定會出現 NullPointerException 異常信息:
public class ArrayDemo { public static void main(String args[]) { int data[] = null; System.out.println(data[x]); } }
這一原則和之前講解的對象是完全相同的。
數組在開發之中一定會使用,但是像上面的操作很少。在以後的實際開發之中,會更多的使用數組概念,而直接使用,99%情況下都隻是做一個 for 循環輸出。
數組引用傳遞
既然數組屬於引用數據類型,那麼也一定可以發生引用傳遞。在這之前首先來研究一下數組的空間開辟。
范例: 觀察一道程序
public class ArrayDemo { public static void main(String args[]) { int data[] = null; data = new int[3]; //開辟一個長度為3的數組 data[0] = 10; data[1] = 20; data[2] = 30; } }
那麼既然說到瞭引用數據類型瞭,就一定可以發生引用傳遞,而現在的引用傳遞的本質也一定是:同一塊堆內存空間可以被不同的棧內存所指向。
范例: 定義一個程序
public class ArrayDemo { public static void main(String args[]) { int data[] = null; data = new int[3]; //開辟一個長度為3的數組 int temp[] = null; //聲明對象 data[0] = 10; data[1] = 20; data[2] = 30; temp = data; //int temp[] = data; temp[0] = 99; for(int i = 0; i < temp.length; i++) { System.out.println(data[i]); } } }
引用傳遞分析都是一個套路。同一塊堆內存被不同的棧內存所指向。
數組靜態初始化
在之前所進行的數組定義都有一個明顯特點:數組先開辟內存空間,而後再使用索引進行內容的設置,實際上這種做法都叫做動態初始化,而如果希望數組在定義的時候可以同時出現設置內容,那麼就可以采用靜態初始化完成。
數組的靜態初始化一共分為以下兩種類型:
Tables | Are |
---|---|
簡化格式: | 數據類型 數組名稱 = {值, 值,…} |
完整格式: | 數據類型 數組名稱 = new 數據類型[] {值, 值,…} |
范例: 采用靜態初始化定義數組
public class ArrayDemo { public static void main(String args[]) { int data[] = {1, 2, 4, 545, 11, 32, 13131, 4444}; for(int i = 0; i < data.length; i++) { System.out.println(data[i]); } } }
在開發之中,對於靜態數組的初始化強烈建議使用完整語法模式,這樣可以輕松地使用匿名數組這一概念。
public class ArrayDemo { public static void main(String args[]) { System.out.println(new int[] {1, 2, 4, 545, 11, 32, 13131, 4444}.length); } }
以後使用靜態方式定義數組的時候一定要寫上完整格式。
數組最大的缺陷:長度固定。
二維數組
在之前所使用的數組發現隻需要一個索引就可以進行訪問,那麼這樣的數組實際上非常像一個數據行的概念。
索引 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
---|---|---|---|---|---|---|---|---|---|
內容 | 12 | 23 | 44 | 56 | 90 | 445 | 49 | 99 | 1010 |
現在痛過一個索引就可以取得唯一的一個記錄。所以這樣的數組可以簡單理解為一維數組,而二維數組本質上指的是行列集合,也如果要確定某一個數據需要行索引和列索引來進行定位。
索引 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
---|---|---|---|---|---|---|---|---|---|
0 | 12 | 23 | 44 | 56 | 90 | 445 | 49 | 99 | 1010 |
1 | 2 | 3 | 41 | 56 | 9 | 45 | 49 | 99 | 10 |
如果要想確定一個數據則數據使用的結構是“數組名稱[行索引][列索引]”,所以這樣的結構就是一個表的結構。
那麼對二維數組的定義有兩種聲明形式:
- 數組的動態初始化:數據類型 對象數組[][] = new 數據類型[行個數][列個數];
- 數組的靜態初始化:數據類型 對象數組[][] = new 數據類型[行個數][列個數]{{值, 值,…}, {值, 值,…},…};
數組的數組就是二維數組。
范例: 定義一個二維數組
public class ArrayDemo { public static void main(String args[]) { //此時的數組並不是一個等列數組 int data[][] = new int[][] { {1, 2, 3}, {4, 5}, {6, 7, 8, 9}}; //如果在進行輸出的時候一定要使用雙重循環, //外部的循環控制輸出的行數,而內部的循環控制輸出列數 for(int i = 0; i < data.length; i++) { for(int j = 0; j < data[i].length; j++) { System.out.print("data[" + i + "][" + j + "]=" + data[i][j] + "、"); } System.out.println(); } } }
由於輸出麻煩,所以可以忽略瞭,在進行開發之中,出現二位數組的幾率並不高。
總結
到此這篇關於Java中數組的定義和使用的文章就介紹到這瞭,更多相關Java數組的定義和使用內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!