標籤:
JAVA 集合類介紹和使用 類別關係 Iterable(介面) │ └--Collection (介面) ├-List(介面) │ ├-LinkedList 不同步 (構造同步:List list = Collections.synchronizedList(new LinkedList(...));) │ ├-ArrayList 不同步 │ └-Vector 同步 │ └--Stack 同步 └-Set ├--EnumSet ├--HashSet --LinkedHashSet └--TreeSet Map ├--Hashtable ├--HashMap --LinkedHashMap └--WeakHashMap Map介面: | + -- WeakHashMap: 以弱鍵 實現的基於雜湊表的 Map。在 WeakHashMap 中,當某個鍵不再正常使用時,將自動移除其條目。更精確地說,對於一個給定的鍵,其映射的存在並不阻止記憶體回收行程對該鍵的丟棄,這就使該鍵成為可終止的,被終止,然後被回收。丟棄某個鍵時,其條目從映射中有效地移除,因此,該類的行為與其他的 Map 實現有所不同。此實現不是同步的。 | + -- TreeMap:該映射根據其鍵的自然順序進行排序,或者根據建立映射時提供的 Comparator 進行排序,具體取決於使用的構造方法。此實現不是同步的。 | + -- HashMap:基於雜湊表的 Map 介面的實現。此實現提供所有可選的映射操作,並允許使用 null 值和 null 鍵。(除了非同步和允許使用 null 之外,HashMap 類與 Hashtable 大致相同。)此類不保證映射的順序,特別是它不保證該順序恒久不變。此實現不是同步的。 | +-- SortedMap: 進一步提供關於鍵的總體排序 的 Map。該映射是根據其鍵的自然順序進行排序的,或者根據通常在建立有序映射時提供的 Comparator 進行排序。對有序映射的 collection 視圖(由 entrySet、keySet 和 values 方法返回)進行迭代時,此順序就會反映出來。要採用此排序方式,還需要提供一些其他動作(此介面是 SortedSet 的對應射)。 Collection介面: | + -- Set介面:一個不包含重複元素的 collection。更正式地說,set 不包含滿足 e1.equals(e2) 的元素對 e1 和 e2,並且最多包含一個 null 元素。正如其名稱所暗示的,此介面模仿了數學上的 set 抽象。 | | | + -- HashSet:此類實現 Set 介面,由雜湊表(實際上是一個 HashMap 執行個體)支援。它不保證 set 的迭代順序;特別是它不保證該順序恒久不變。此類允許使用 null 元素。此類為基本操作提供了穩定效能,此實現不是同步的。 | | | + -- LinkedHashSet:具有可預知迭代順序的 Set 介面的雜湊表和連結清單實現。此實現與 HashSet 的不同之外在於,後者維護著一個運行於所有條目的雙重連結清單。此連結清單定義了迭代順序,即按照將元素插入到 set中的順序(插入順序)進行迭代。注意,插入順序不 受在 set 中重新插入的 元素的影響。此實現不是同步的。 | | | + -- TreeSet:基於 TreeMap 的 NavigableSet 實現。使用元素的自然順序對元素進行排序,或者根據建立 set 時提供的 Comparator 進行排序,具體取決於使用的構造方法。此實現為基本操作(add、remove 和 contains)提供受保證的 log(n) 時間開銷。此實現不是同步的。 | + -- List介面:有序的 collection(也稱為序列)。此介面的使用者可以對列表中每個元素的插入位置進行精確地控制。使用者可以根據元素的整數索引(在列表中的位置)訪問元素,並搜尋列表中的元素。 | + -- ArrayList:List 介面的大小可變數組的實現。實現了所有可選列表操作,並允許包括 null 在內的所有元素。除了實現 List 介面外,此類還提供一些方法來操作內部用來儲存列表的數組的大小。(此類大致上等同於Vector 類,除了此類是不同步的。)每個 ArrayList 執行個體都有一個容量。該容量是指用來儲存列表元素的數組的大小。它總是至少等於列表的大小。隨著向 ArrayList 中不斷添加元素,其容量也自動成長。並未指定增長策略的細節,因為這不只是添加元素會帶來分攤固定時間開銷那樣簡單。此實現不是同步的。 | + -- LinkedList:List 介面的連結清單實現。實現所有可選的列表操作,並且允許所有元素(包括 null)。除了實現 List 介面外,LinkedList 類還為在列表的開頭及結尾 get、remove 和 insert 元素提供了統一的命名方法。這些操作允許將連結清單用作堆棧、隊列或雙端隊列。提供先進先出隊列操作(FIFO)。此實現不是同步的。 | + -- Vector:Vector 類可以實現可增長的對象數組。與數組一樣,它包含可以使用整數索引進行訪問的組件。但是,Vector 的大小可以根據需要增大或縮小,以適應建立 Vector 後進行添加或移除項的操作。此實現是同步的. Collection介面 Collection是最基本的集合介面,一個Collection代表一組Object,即Collection的元素(Elements)。一些 Collection允許相同的元素而另一些不行。一些能排序而另一些不行。Java SDK不提供直接繼承自Collection的類,Java SDK提供的類都是繼承自Collection的“子介面”如List和Set。 所有實現Collection介面的類都必須提供兩個標準的建構函式:無參數的建構函式用於建立一個空的Collection,有一個Collection參數的建構函式用於建立一個新的Collection,這個新的Collection與傳入的Collection有相同的元素。後一個建構函式允許使用者複製一個Collection。 如何遍曆Collection中的每一個元素?不論Collection的實際類型如何,它都支援一個iterator()的方法,該方法返回一個迭代子,使用該迭代子即可逐一訪問Collection中每一個元素。典型的用法如下: Iterator it = collection.iterator(); // 獲得一個迭代子 while(it.hasNext()) { Object obj = it.next(); // 得到下一個元素 } 由Collection介面派生的兩個介面是List和Set。 List介面 List是有序的Collection,使用此介面能夠精確的控制每個元素插入的位置。使用者能夠使用索引(元素在List中的位置,類似於數組下標)來訪問List中的元素,這類似於Java的數組。 和下面要提到的Set不同,List允許有相同的元素。 除了具有Collection介面必備的iterator()方法外,List還提供一個listIterator()方法,返回一個 ListIterator介面,和標準的Iterator介面相比,ListIterator多了一些add()之類的方法,允許添加,刪除,設定元素,還能向前或向後遍曆。 實現List介面的常用類有LinkedList,ArrayList,Vector和Stack。 LinkedList類 LinkedList實現了List介面,允許null元素。此外LinkedList提供額外的get,remove,insert方法在 LinkedList的首部或尾部。這些操作使LinkedList可被用作堆棧(stack),隊列(queue)或雙向隊列(deque)。 注意LinkedList沒有同步方法。如果多個線程同時訪問一個List,則必須自己實現訪問同步。一種解決方案是在建立List時構造一個同步的List: List list = Collections.synchronizedList(new LinkedList(...)); ArrayList類 ArrayList實現了可變大小的數組。它允許所有元素,包括null。ArrayList沒有同步。 size,isEmpty,get,set方法已耗用時間為常數。但是add方法開銷為分攤的常數,添加n個元素需要O(n)的時間。其他的方法已耗用時間為線性。 www.2cto.com 每個ArrayList執行個體都有一個容量(Capacity),即用於儲存元素的數組的大小。這個容量可隨著不斷添加新元素而自動增加,但是增長演算法並沒有定義。當需要插入大量元素時,在插入前可以調用ensureCapacity方法來增加ArrayList的容量以提高插入效率。 和LinkedList一樣,ArrayList也是非同步的(unsynchronized)。 Vector類 Vector非常類似ArrayList,但是Vector是同步的。由Vector建立的Iterator,雖然和ArrayList建立的 Iterator是同一介面,但是,因為Vector是同步的,當一個Iterator被建立而且正在被使用,另一個線程改變了Vector的狀態(例如,添加或刪除了一些元素),這時調用Iterator的方法時將拋出ConcurrentModificationException,因此必須捕獲該異常。 Stack 類 Stack繼承自Vector,實現一個後進先出的堆棧。Stack提供5個額外的方法使得Vector得以被當作堆棧使用。基本的push和pop方法,還有peek方法得到棧頂的元素,empty方法測試堆棧是否為空白,search方法檢測一個元素在堆棧中的位置。Stack剛建立後是空棧。 */ package myapp.data; import myapp.model.Article; import java.text.DateFormat; import java.text.ParseException; import java.util.*; import java.util.Map.Entry; public class CollectionMethodTest { private static List<Article> list=new ArrayList<Article>(6); public static void initialize() throws ParseException{ DateFormat df = DateFormat.getDateInstance(DateFormat.LONG, Locale.FRANCE); list.add(new Article(1,"NBA1","Carl1","NBA Start1",df.parse("2010-01-1"),1)); list.add(new Article(2,"NBA2","Carl2","NBA Start2",df.parse("2010-01-2"),2)); list.add(new Article(3,"NBA3","Carl3","NBA Start3",df.parse("2010-01-3"),3)); list.add(new Article(4,"NBA4","Carl4","NBA Start4",df.parse("2010-01-4"),4)); list.add(new Article(5,"NBA5","Carl5","NBA Start5",df.parse("2010-01-5"),5)); list.add(new Article(6,"NBA6","Carl6","NBA Start6",df.parse("2010-01-6"),6)); } //列表通常允許重複的元素 ,允許NULL元素,有序 //原型:public interface List<E> extends Collection<E> //常用實作類別: AbstractList, ArrayList, LinkedList, Stack, Vector public void listTest(){ } //HashMap:允許使用 null 值和 null 鍵,不同步,實現了Map介面和AbstractMap抽象類別 //原型:public class HashMap<K,V> extends AbstractMap<K,V> implements Map<K,V>, Cloneable, Serializable public void hashMapTest(){ System.out.println("--------HashMap遍曆------"); Map<Integer, String> map=new HashMap<Integer,String>(); for(Article a : list){ map.put(a.getId(), a.getTitle()+a.getContent()); } //得到map的所有的鍵 Set<Integer> keys=map.keySet(); //得到map的所有的值 Collection<String> values=map.values(); //返回包含在此映射中的映射關係的 Set 視圖。 Set<Map.Entry<Integer, String>> setEntry=map.entrySet(); //使用Iterator遍曆器遍曆 System.out.println("--------使用Iterator遍曆器遍曆------"); Iterator<Entry<Integer,String>> it = setEntry.iterator(); while(it.hasNext()){ Entry<Integer,String> e = it.next(); System.out.println("Id:"+e.getKey()+" Description:"+e.getValue()); } //使用for遍曆 System.out.println("--------使用for遍曆------"); for(Entry<Integer,String> e:setEntry){ System.out.println("Id:"+e.getKey()+" Description:"+e.getValue()); } } //Set:一個不包含重複元素的 collection。更正式地說,set 不包含滿足 e1.equals(e2) 的元素對 e1 和 e2,並且最多包含一個 null 元素 //原型:public interface Set<E> extends Collection<E> //實作類別: AbstractSet, EnumSet, HashSet, LinkedHashSet, TreeSet、 JobStateReasons,CopyOnWriteArraySet public void setTest(){ Set<String> set=new HashSet<String>(); set.add("No1"); set.add("No2"); set.add("No3"); } }
摘自 twoicewoo的專欄
摘抄轉載前輩們的Java集合類總結