摘抄轉載前輩們的Java集合類總結

來源:互聯網
上載者:User

標籤:

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集合類總結

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.