145
魔獸
Java集合-List
java.util.List
接口是java.util.Collection
接口的一個子接口。它表示對象的一個有序列表,意味你可以特定的順序訪問元素,也可以通過索引訪問。也可以向一個 List
中多次添加重複的元素。
Java List 視頻教程
如果你更喜歡看視頻而不是文本,下麵是一個版本的Java List視頻教程。
https://youtu.be/d3QbptJRln4
List實現
作為一個Collection的子類型,Collection接口的所有方法在List接口裏也適用。
因為List
是一個接口,為了使用它,你必須實例化一個具體的實現,你可以在下列List的實現中選擇:
- java.util.ArrayList
- java.util.LinkedList
- java.util.Vector
- java.util.Stack
在java.util.concurrent
包中,同樣也有List
的實現,但是在本教程中,我將不考慮並發程序。
下麵是創建List
實例的一些例子
List listA = new ArrayList(); List listB = new LinkedList(); List listC = new Vector(); List listD = new Stack();
新增和讀取元素
向一個List
中增加元素可以調用 add()
方法,這個方法從Collection接口繼承而來,下麵是一些例子
List listA = new ArrayList(); listA.add("element 1"); listA.add("element 2"); listA.add("element 3"); listA.add(0, "element 0");
前三個 add()
方法在list的末尾增加一個String
。最後一個 add()
方法在索引0處增加一個String
,就是list的開頭。
增加元素到List
的順序被儲存,所以你可以按照同樣的順序讀取元素。你也可以使用get(int index)
方法或者通過iterator()
方法返回的Iterator
對象來做這件事情。下麵是例子
List listA = new ArrayList(); listA.add("element 0"); listA.add("element 1"); listA.add("element 2"); //access via index String element0 = listA.get(0); String element1 = listA.get(1); String element3 = listA.get(2); //access via Iterator Iterator iterator = listA.iterator(); while(iterator.hasNext(){ String element = (String) iterator.next(); } //access via new for-loop for(Object object : listA) { String element = (String) object; }
當通過Iterator
或者for循環迭代list的時候,元素按照他們被存儲的順序被迭代。
移除元素
你有兩種方式去移除元素
- remove(Object element)
- remove(int index)
remove(Object element)
移除list中存在的元素。所有後續的元素向前移動,索引因此減少1。
清空一個List
Java List
接口包含一個clear()
方法,作用是移除所有的元素。下麵是個簡單的例子
List list = new ArrayList(); list.add("object 1"); list.add("object 2"); //etc. list.clear();
List的大小
你可以獲取List
中元素的個數通過調用size()
方法,下麵是個例子
List list = new ArrayList(); list.add("object 1"); list.add("object 2"); int size = list.size();
泛型列表
默認你可以放入一個Object到一個List
中,但是從Java 5起,Java泛型使限製你可以放入一個List
的類型成為可能,下麵是例子
List<MyObject> list = new ArrayList<MyObject>();
List
現在隻有MyObject
的實例可以插入進去,你可以迭代和讀取它的元素而不用強製轉化它們,就像下麵這樣
MyObject myObject = list.get(0); for(MyObject anObject : list){ //do someting to anObject... }
迭代一個列表
迭代一個Java List
有幾種不同的方式,我將在這裏展示三種最常見的方式。
第一種方式是利用一個Iterator
,下麵是一個例子
List list = new ArrayList(); //add elements to list Iterator iterator = list.iterator(); while(iterator.hasNext()) { Object next = iterator.next(); }
你可以獲取一個Iterator
通過調用List
接口的iterator()
方法。
一旦你獲取了一個Iterator
,可以不停的調用它的 hasNext()
方法直到返回false。
像你看到的,在while
循環中調用hasNext()
方法。
在while
循環中你可以調用next()
方法來獲取Iterator
指針指向的下一個元素。
下麵是例子
List<String> mylistStr = new ArrayList<>(); Iterator<String> iterator = mylistStr.iterator(); while(iterator.hasNext()){ String obj = iterator.next(); }
另外一種迭代的方式是使用Java 5中新增的for循環,下麵是個例子
List list = new ArrayList(); //add elements to list for(Object obj : list) { }
List
中的每個元素都會被執行一個for循環,在for循環中,每個元素輪流綁定到obj變量上。
如果是一個泛型列表,可以在for循環中轉換變量類型,下麵是例子
List<String> list = new ArrayList<String>(); //add elements to list for(String obj : list) { }
注意List
怎麼被限製為String
,因此你可以在for循環中將一個變量設置為String
。
最後一種迭代列表的方式是使用傳統的for循環
List list = new ArrayList(); //add elements to list for(int i=0; i < list.size(); i++) { Object obj = list.get(i); }
for循環創建一個int類型變量並把它初始化為0,當i小於列表長度的時候,一直循環。每一次循環i將會自增。
在JavaDoc中有更多細節
一個List
有許多你可以做的事情,但是你必須查看文檔獲取更多的細節。本篇文章重點在兩個普通的操作:增加、移除元素,並且迭代它們。
最後更新:2017-05-22 14:02:19