【Java】集合類、容器接口(1)

關(guān)于collection接口

Collection 表示一組對(duì)象,這些對(duì)象也稱為 collection 的元素,元素是獨(dú)立的。

我們一般用到的collection往往是他的子接口的實(shí)現(xiàn)類。

常用的子接口:

Collection是對(duì)Iterable接口的拓展。故所有的Collection對(duì)象都可以使用foreach方式,對(duì)元素進(jìn)行方便的遍歷。

由于Iterable接口中定義了的唯一方法為:返回一個(gè)Iterator對(duì)象,故所有的Collection都可以用 對(duì)象名.iterator()的方式獲取該collection的迭代器iterator對(duì)象。

例:

Collection coll = new ArrayList(); //LinkedList(); ArrayList();實(shí)現(xiàn)類  
coll.add("Tody");  
coll.add("is");  
coll.add("Sunday.");  

關(guān)于list接口

List<E>接口繼承了Collection接口,并且增加了有序的特點(diǎn)。同時(shí)它允許重復(fù)的元素。

此接口的用戶可以對(duì)列表中每個(gè)元素的插入位置進(jìn)行精確地控制。用戶可以根據(jù)元素的整數(shù)索引(在列表中的位置)訪問元素,并搜索列表中的元素。

常用的子類:

ArrayList實(shí)現(xiàn)了可變大小的數(shù)組。它允許所有元素,包括null。
ArrayList沒有同步。size,isEmpty,get,set方法運(yùn)行時(shí)間為常數(shù)。但是add方法開銷為分?jǐn)偟某?shù),添加n個(gè)元素需要O(n)的時(shí)間。其他的方法運(yùn)行時(shí)間為線性。每個(gè)ArrayList實(shí)例都有一個(gè)容量(Capacity),即用于存儲(chǔ)元素的數(shù)組的大小。這個(gè)容量可隨著不斷添加新元素而自動(dòng)增加,但是增長(zhǎng)算法并沒有定義。當(dāng)需要插入大量元素時(shí),在插入前可以調(diào)用ensureCapacity方法來增加ArrayList的容量以提高插入效率。
【非同步】

LinkedList實(shí)現(xiàn)了List接口,允許null元素。此外LinkedList提供額外的get,remove,insert方法在 LinkedList的首部或尾部。這些操作使LinkedList可被用作堆棧(stack),隊(duì)列(queue)或雙向隊(duì)列(deque)。
【非同步】

Vector非常類似ArrayList,但是Vector是【同步】的。由Vector創(chuàng)建的Iterator,雖然和ArrayList創(chuàng)建的 Iterator是同一接口,但是,因?yàn)閂ector是同步的,當(dāng)一個(gè) Iterator被創(chuàng)建而且正在被使用,另一個(gè)線程改變了Vector的狀態(tài)(例如,添加或刪除了一些元素),這時(shí)調(diào)用Iterator的方法時(shí)將拋出 ConcurrentModificationException,因此必須捕獲該異常。

Stack繼承自Vector,實(shí)現(xiàn)一個(gè)后進(jìn)先出的堆棧。Stack提供5個(gè)額外的方法使得Vector得以被當(dāng)作堆棧使用?;镜膒ush和pop方法,還有 peek方法得到棧頂?shù)脑?,empty方法測(cè)試堆棧是否為空,search方法檢測(cè)一個(gè)元素在堆棧中的位置。Stack剛創(chuàng)建后是空棧。

List l = new ArrayList();
Iterator iter = l.iterator();

關(guān)于Set接口

一個(gè)不包含重復(fù)元素的 collection。更確切地講,set 不包含滿足 e1.equals(e2) 的元素對(duì) e1 和 e2,并且最多包含一個(gè) null 元素。

可以進(jìn)行排序。

常用子類:

HashSet它不允許出現(xiàn)重復(fù)元素;不保證集合中元素的順序;允許包含值為null的元素,但最多只能有一個(gè)null元素。

TreeSet描述的是Set的一種變體——可以實(shí)現(xiàn)排序等功能的集合,它在講對(duì)象元素添加到集合中時(shí)會(huì)自動(dòng)按照某種比較規(guī)則將其插入到有序的對(duì)象序列中。String就是升序。

Set<String> s =null;
s= new TreeSet<String>();
s.add("A");
s.add("B");
s.add("D");
s.add("C");
s.add("T");
s.add("E");
System.out.println(s);//結(jié)果就是有序的 [A, B, C, D, E, T]
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容