欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Java集合繼承體系詳解-創(chuàng)新互聯(lián)

Java的集合類是一種特別有用的工具,它可以用于存儲數(shù)量不等的多個(gè)對象,并可以實(shí)現(xiàn)常用的數(shù)據(jù)結(jié)構(gòu),如棧、隊(duì)列等。Java集合還可以用于板寸具有映射關(guān)系的關(guān)聯(lián)數(shù)組。

成都創(chuàng)新互聯(lián)公司專注骨干網(wǎng)絡(luò)服務(wù)器租用10余年,服務(wù)更有保障!服務(wù)器租用,成都IDC機(jī)房托管 成都服務(wù)器租用,成都服務(wù)器托管,骨干網(wǎng)絡(luò)帶寬,享受低延遲,高速訪問。靈活、實(shí)現(xiàn)低成本的共享或公網(wǎng)數(shù)據(jù)中心高速帶寬的專屬高性能服務(wù)器。

java集合就像是一個(gè)容器,我們可以把多個(gè)對象(實(shí)際上是對象的引用,習(xí)慣上叫對象,)保存到集合容器中。在JDK1.5以前java集合會丟失容器中所有對象的數(shù)據(jù)類型,JDK1.5以后增加了泛型,java集合可以記住容器中對象的數(shù)據(jù)類型。

Java集合大致可以分為三個(gè)體系:Set List Map.所有的集合類都位于java.util包下面。

Collection接口


Collection接口是List、 Set、和Queue接口的父接口。
Collection所代表的是一種規(guī)則,它所包含的元素都必須遵循一條或者多條規(guī)則。如有些允許重復(fù)而有些則不能重復(fù)、有些必須要按照順序插入而有些則是散列,有些支持排序有些不支持排序。


一、List接口

List接口是Collection接口的直接接口。List代表的是有序的Collection,集合中的每個(gè)元素都有其對應(yīng)的索引。List中允許有重復(fù)的元素,可以通過索引來訪問指定位置的集合元素。因?yàn)長ist集合默認(rèn)按元素的添加順序設(shè)置元素的索引。


(1)ArrayList、Vector、Stack


ArrayList和Vector作為List的兩個(gè)典型實(shí)現(xiàn)類,完全支持List的全部功能。


ArrayList和Vector類的底層都是基于數(shù)組來儲存集合元素,封裝了一個(gè)動態(tài)的Object[]數(shù)組,是一種順序存儲的線性表。


ArrayList和Vector在用法上幾乎完全相同,只是Vector在JDK1.0時(shí)就存在,它的方法名比較冗長、比ArrayList包含的方法多,源碼比ArrayList包含的源碼也多,ArrayList的序列化實(shí)現(xiàn)比Vector現(xiàn)在Vector基本上被ArrayList所取代了。


主要區(qū)別:ArrayList是線程不安全的,Vector是線程安全的。


如果需要在多線程環(huán)境下使用List集合,而且需要保證線程安全,依然可以避免使用Vector,而是考慮將ArrayList包裝成線程安全的集合類。Java提供的Collections工具類,通過該工具類synchronizeList方法即可以把ArrayList包裝成線程安全的ArrayList.

Stack

Vector提供了一個(gè)子類,它用于模擬“?!边@種數(shù)據(jù)結(jié)構(gòu),棧通常是先進(jìn)后出的容器。Stack提供了額外的5個(gè)方法,使得Vector可以當(dāng)做棧來使用。出棧pop,入棧push,訪問棧頂元素peek(),判斷棧是否為空empty(),檢測一個(gè)元素在堆棧中的位置serch().


(2)LinkedList

LinkedList是一個(gè)鏈?zhǔn)酱鎯Φ木€性變,本質(zhì)上是一個(gè)雙向鏈表,它不僅實(shí)現(xiàn)了List接口還實(shí)現(xiàn)了Dueue接口(雙端隊(duì)列,既具有隊(duì)列的特征,也具有棧的特征),所以LinkedList不僅可以做雙向鏈表來使用,還可以當(dāng)棧和隊(duì)列來使用。


LinkedList對元素的插入、刪除元素時(shí)速度非??臁?/p>

LinkdedList也是非同步的。若要實(shí)現(xiàn)同步訪問,可以采取
List list = Collections.synchronizeList(new LinkedList(.....));


(3)異同點(diǎn)對比

 (1)ArrayList和LinkedList


1)ArrayList是基于動態(tài)數(shù)組實(shí)現(xiàn)的,LinkedList是基于雙向鏈表實(shí)現(xiàn)的。
2)ArrayList比較適用于隨機(jī)存取,(可直接通過索引,LinkedList需要通過指針遍歷);LinkedList比較適用于增加刪除操作(對于單條的插入和刪除操作ArrayList比LinkedList速度快,對于插入好人刪除操作,ArrayList需要移動后面的所有元素。)


二、Set接口

Set是一種不允許包含相同元素的Collection。它維持自己的內(nèi)部排序,隨機(jī)訪問沒有任何意義。


(1)HashSet

HashSet是Set接口的典型實(shí)現(xiàn),HashSet按Hash算法來儲存集合中的元素,具有很好的存取和查找功能。
具有以下特點(diǎn):


1)不保證元素的排列順序,有可能變化;
2)HashSet不是同步的;
3)集合元素可以為空。


(2)TreeSet

 TreeSet是SortedSet接口的唯一實(shí)現(xiàn),TreeSet可以確保元素處于排序狀態(tài),TreeSet并不是根據(jù)元素的插入順序進(jìn)行排序的,而是根據(jù)實(shí)際值進(jìn)行排序。支持兩種排序方式:自然排序和定制排序。


(3)EnumSet

是為枚舉類設(shè)計(jì)的集合類,EnumSet不允許加入null元素。如果試圖插入null,會拋出空指針異常。
Set的三個(gè)實(shí)現(xiàn)類都是現(xiàn)成不安全的。


三、Map接口

Map保存具有映射關(guān)系的數(shù)據(jù),因此Map集合里保存著兩組值,一組值用來保存Map里的key,一組用來保存Map里的value,key和value可以是任何引用類型的數(shù)據(jù)。


Map里的key不允許重復(fù),value可以重復(fù)。key和value之間存在單向的一對一的關(guān)系,通過指定的key,總能找到唯一的、確定的value。


(1)HashMap與HashTable

HashMap與HashTable都是Map的典型實(shí)現(xiàn)類,他們之間的關(guān)系類似于ArrayList和Vector:HashTable是一個(gè)古老的Map實(shí)現(xiàn)類,在JDK1.0時(shí)就出現(xiàn)了。


主要區(qū)別:


1)HashTable是一個(gè)線程安全的Map實(shí)現(xiàn),但是HashMap是線程不安全的實(shí)現(xiàn),HashMap的性能要比HashTable高一些,盡量避免使用HashTable,多個(gè)線程訪問一個(gè)Map對象又要保證線程安全時(shí),可以使用Collections中的方法把HashMap變成線程安全的。
2)HashTable不允許使用null作為key和value,如果試圖把null加入HashTable中,將會引發(fā)空指針異常。


(2)TreeMap

TreeMap是Map的子接口SortedMap的的實(shí)現(xiàn)類,與TreeSet類似的是TreeMap也是基于紅黑樹對TreeMap中所有的key進(jìn)行排序,從而保證key-value處于有序狀態(tài),TreeMap也有兩種排序方式:


1)自然排序:TreeMap的所有key必須實(shí)現(xiàn)Comparable接口,而且所有key應(yīng)該是同一類的對象,否則會拋出ClassCastException.


2)定制排序:創(chuàng)建TreeMap時(shí),傳入一個(gè)Comparator對象,該對象負(fù)責(zé)對TreeMap中所有的key進(jìn)行排序。
由于TreeMap支持內(nèi)部排序,所以通常要比HashMap和HashTable慢。


四、Queue接口

Queue模擬了隊(duì)列這種數(shù)據(jù)結(jié)構(gòu),隊(duì)列通常是“先進(jìn)先出”的數(shù)據(jù)結(jié)構(gòu),通常不允許隨機(jī)訪問隊(duì)列中的元素。
Queue常用的實(shí)現(xiàn)類:LinkedList和PriorityQueue


(1)LinkedList

LinkedList它不僅實(shí)現(xiàn)了List接口還實(shí)現(xiàn)了Dueue接口(雙端隊(duì)列,既具有隊(duì)列的特征,也具有棧的特征),Dueue接口是Queue的子接口。


(2)PriorityQueue

PriorityQueue保存隊(duì)列元素的的順序并不是按照加入隊(duì)列的順序,而是按照隊(duì)列元素大小進(jìn)行重新排序。所以當(dāng)調(diào)用peek和poll方法來取隊(duì)列中的元素的時(shí)候,并不是先取出來隊(duì)列中最小的元素。從這個(gè)意義上來看,PriorityQueue已經(jīng)違反了隊(duì)列的基本規(guī)則。PriorityQueue不允許插入null元素。


總結(jié):

線程安全的有Vector Stack HashTable


不允許插入空元素的有HashTable PriorityQueue EnumSet

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

當(dāng)前文章:Java集合繼承體系詳解-創(chuàng)新互聯(lián)
網(wǎng)頁地址:http://aaarwkj.com/article0/dpehio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、品牌網(wǎng)站設(shè)計(jì)、靜態(tài)網(wǎng)站、標(biāo)簽優(yōu)化網(wǎng)站營銷、網(wǎng)站導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計(jì)
91九色在线精品人妻| 午夜影院在线观看网站| 国产日韩综合精品一区| 国产亚洲精品第一综合| 国产精品亚洲伦理在线| 亚洲国产精品午夜福利在线播放| 白色发布会在线观看免费| 国产一区二区欧美精品| 国产毛片一区二区三区二区| 最近中文字幕免费手机版| 亚洲成av人在线播放| 偷窥偷拍视频一区二区| 亚洲中文字幕乱码第一页| 日本免费一区中文字幕| 国产亚洲欧美日韩各类| 成人国产视频免费观看| 五月婷婷少妇中文字幕| 国产成年人拍拍免费视频| 日本丝袜福利在线观看| 日韩国产精品一区二区| 中文字幕人妻秘书社长| 国产自拍精品视频免费观看| 日韩高清视频 一区二区| 91九色国产在线播放| 亚洲熟女内射特写一区| 黄片视频免费观看一起草| 欧美精品福利一区二区三区| 精品少妇高潮蜜臀av| 天堂免费av在线播放| 18以下的人禁止看的视频| 国产色综合一区二区| 91精品国内手机在线高清| 欧美日韩综合精品无人区| 日韩精品一区二区三区四区在线视频| 欧美一级午夜欧美午夜视频| 最新免费观看男女啪啪视频| 亚洲一区二区三区久久伊人| 午夜精品人妻一区二区| 未满十八禁止在线观看av| 久久精品国产av一一区| 欧美日韩一级特黄大片|