在Java中,數組(array)和列表(list)都是常用的數據結構,但它們之間有著明顯的區別。
數組(array)
int[] arr = new int[5];
arr[0] = 1;
arr[1] = 2;
arr[2] = 3;
arr[3] = 4;
arr[4] = 5;
數組是一種基本數據結構,用于存儲一組有序的元素,這些元素可以是任何類型。數組的大小在創建時確定,一旦確定,大小就不能再改變。數組可以通過索引訪問元素,索引從0開始。Java中的數組可以是單維數組,多維數組和不規則數組。
int[][] arr = new int[2][3];
arr[0][0] = 1;
arr[0][1] = 2;
arr[0][2] = 3;
arr[1][0] = 4;
arr[1][1] = 5;
arr[1][2] = 6;
列表(list)
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
list.add(4);
list.add(5);
列表是一個接口,它定義了一組可以操作元素的方法。列表的實現類有ArrayList,LinkedList等。列表的大小可以動態地改變,可以添加或刪除元素,而不需要重新創建列表。列表可以通過索引訪問元素,索引從0開始。
List<List<Integer>> list = new ArrayList<>();
List<Integer> temp = new ArrayList<>();
temp.add(1);
temp.add(2);
temp.add(3);
list.add(temp);
temp = new ArrayList<>();
temp.add(4);
temp.add(5);
temp.add(6);
list.add(temp);
數組和列表的區別
數組和列表在存儲元素,訪問元素這些基本操作上有相似之處,但它們還是有著不同的特點。
首先,數組在創建時就需要給定大小,大小不能改變,而列表的大小可以動態地改變。其次,數組可以存儲任何類型的元素,而列表只能存儲一種類型的元素。最后,數組訪問元素的速度比訪問列表中的元素快。
綜上所述,選擇使用數組還是列表,需要根據具體的情況和需求來進行選擇。