亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > list/set/map的區別

list/set/map的區別

來源:千鋒教育
發布人:qyf
時間: 2022-06-07 16:00:00 1654588800

java培訓

  一、List接口

  List是一個繼承于Collection的接口,即List是集合中的一種。List是有序的隊列,List中的每一個元素都有一個索引;第一個元素的索引值是0,往后的元素的索引值依次+1。和Set不同,List中允許有重復的元素。實現List接口的集合主要有:ArrayList、LinkedList、Vector、Stack。

  ArrayList

  ArrayList是一個動態數組,也是我們最常用的集合。它允許任何符合規則的元素插入甚至包括null。每一個ArrayList都有一個初始容量:

  private static final int DEFAULT_CAPACITY = 10;

  隨著容器中的元素不斷增加,容器的大小也會隨著增加。在每次向容器中增加元素的同時都會進行容量檢查,當快溢出時,就會進行擴容操作。所以如果我們明確所插入元素的多少,最好指定一個初始容量值,避免過多的進行擴容操作而浪費時間、效率。

  size、isEmpty、get、set、iterator 和 listIterator 操作都以固定時間運行。add 操作以分攤的固定時間運行,也就是說,添加 n 個元素需要 O(n) 時間(由于要考慮到擴容,所以這不只是添加元素會帶來分攤固定時間開銷那樣簡單)。

  ArrayList擅長于隨機訪問。同時ArrayList是非同步的。

  LinkedList

  同樣實現List接口的LinkedList與ArrayList不同,ArrayList是一個動態數組,而LinkedList是一個雙向鏈表。所以它除了有ArrayList的基本操作方法外還額外提供了get,remove,insert方法在LinkedList的首部或尾部。

  由于實現的方式不同,LinkedList不能隨機訪問,它所有的操作都是要按照雙重鏈表的需要執行。在列表中索引的操作將從開頭或結尾遍歷列表(從靠近指定索引的一端,節約一半時間)。這樣做的好處就是可以通過較低的代價在List中進行插入和刪除操作。

  與ArrayList一樣,LinkedList也是非同步的。如果多個線程同時訪問一個List,則必須自己實現訪問同步。一種解決方法是在創建List時構造一個同步的List:

  List list = Collections.synchronizedList(new LinkedList(…));

  Vector

  與ArrayList相似,但是Vector是同步的。所以說Vector是線程安全的動態數組。它的操作與ArrayList幾乎一樣。

  Stack

  Stack繼承自Vector,實現一個后進先出的堆棧。Stack提供5個額外的方法使得Vector得以被當作堆棧使用。基本的push和pop方法,還有peek方法得到棧頂的元素,empty方法測試堆棧是否為空,search方法檢測一個元素在堆棧中的位置。Stack剛創建后是空棧。

  二、Set接口

  Set是一個繼承于Collection的接口,Set是一種不包括重復元素的Collection。它維持它自己的內部排序,所以隨機訪問沒有任何意義。與List一樣,它同樣運行null的存在但是僅有一個。由于Set接口的特殊性,所有傳入Set集合中的元素都必須不同,關于API方面。Set的API和Collection完全一樣。實現了Set接口的集合有:HashSet、TreeSet、LinkedHashSet、EnumSet。

  HashSet

  HashSet堪稱查詢速度最快的集合,因為其內部是以HashCode來實現的。集合元素可以是null,但只能放入一個null。它內部元素的順序是由哈希碼來決定的,所以它不保證set的迭代順序;特別是它不保證該順序恒久不變。

  TreeSet

  TreeSet是二叉樹實現的,基于TreeMap,生成一個總是處于排序狀態的set,內部以TreeMap來實現,不允許放入null值。它是使用元素的自然順序對元素進行排序,或者根據創建Set時提供的 Comparator 進行排序,具體取決于使用的構造方法。

  LinkedHashSet

  LinkedHashSet集合同樣是根據元素的hashCode值來決定元素的存儲位置,但是它同時使用鏈表維護元素的次序。這樣使得元素看起 來像是以插入順序保存的,也就是說,當遍歷該集合時候,LinkedHashSet將會以元素的添加順序訪問集合的元素。LinkedHashSet在迭代訪問Set中的全部元素時,性能比HashSet好,但是插入時性能稍微遜色于HashSet。

  三、Map接口

  Map與List、Set接口不同,它是由一系列鍵值對組成的集合,提供了key到Value的映射。在Map中它保證了key與value之間的一一對應關系。也就是說一個key對應一個value,所以它不能存在相同的key值,當然value值可以相同。實現map的集合有:HashMap、HashTable、TreeMap、WeakHashMap。

  HashMap

  以哈希表數據結構實現,查找對象時通過哈希函數計算其位置,它是為快速查詢而設計的,其內部定義了一個hash表數組(Entry[] table),元素會通過哈希轉換函數將元素的哈希地址轉換成數組中存放的索引,如果有沖突,則使用散列鏈表的形式將所有相同哈希地址的元素串起來,可能通過查看HashMap.Entry的源碼它是一個單鏈表結構。

  HashTable

  也是以哈希表數據結構實現的,解決沖突時與HashMap也一樣也是采用了散列鏈表的形式。HashTable繼承Dictionary類,實現Map接口。其中Dictionary類是任何可將鍵映射到相應值的類(如 Hashtable)的抽象父類。每個鍵和每個值都是一個對象。在任何一個 Dictionary 對象中,每個鍵至多與一個值相關聯。Map是”key-value鍵值對”接口。 HashTable采用”拉鏈法”實現哈希表不過性能比HashMap要低。

  TreeMap

  有序散列表,實現SortedMap接口,底層通過紅黑樹實現。

  WeakHashMap

  談WeakHashMap前先看一下Java中的引用(強度依次遞減)

  1. 強引用:普遍對象聲明的引用,存在便不會GC

  2. 軟引用:有用但并非必須,發生內存溢出前,二次回收

  3. 弱引用:只能生存到下次GC之前,無論是否內存足夠

  4. 虛引用:唯一目的是在這個對象被GC時能收到一個系統通知

  以弱鍵實現的基于哈希表的Map。在 WeakHashMap 中,當某個鍵不再正常使用時,將自動移除其條目。更精確地說,對于一個給定的鍵,其映射的存在并不阻止垃圾回收器對該鍵的丟棄,這就使該鍵成為可終止的,被終止,然后被回收。丟棄某個鍵時,其條目從映射中有效地移除,因此,該類的行為與其他的 Map 實現有所不同。null值和null鍵都被支持。該類具有與HashMap類相似的性能特征,并具有相同的效能參數初始容量和加載因子。像大多數集合類一樣,該類是不同步的。

  四、總結

  1、List、Set都是繼承自Collection接口,Map則不是

  2、List特點:元素有放入順序,元素可重復 ,Set特點:元素無放入順序,元素不可重復,重復元素會覆蓋掉,(注意:元素雖然無放入順序,但是元素在set中的位置是有該元素的HashCode決定的,其位置其實是固定的,加入Set 的Object必須定義equals()方法 ,另外list支持for循環,也就是通過下標來遍歷,也可以用迭代器,但是set只能用迭代,因為他無序,無法用下標來取得想要的值。)

  3、Set和List對比:

  Set:檢索元素效率低下,刪除和插入效率高,插入和刪除不會引起元素位置改變。

  List:和數組類似,List可以動態增長,查找元素效率高,插入刪除元素效率低,因為會引起其他元素位置改變。

  4、Map適合儲存鍵值對的數據

  5、線程安全集合類與非線程安全集合類 :

  · LinkedList、ArrayList、HashSet是非線程安全的,Vector是線程安全的;

  · HashMap是非線程安全的,HashTable是線程安全的;

  · StringBuilder是非線程安全的,StringBuffer是線程安全的。

  更多關于“Java培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓經驗,課程大綱更科學更專業,有針對零基礎的就業班,有針對想提升技術的好程序員班,高品質課程助理你實現java程序員夢想。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
脱了老师内裤猛烈进入的软件| 天天天欲色欲色WWW免费| 日韩免费无码视频一区二区三区| 四虎成人精品一区二区免费网站| 亚洲AV无码不卡在线播放| 亚洲熟妇AV一区二区三区| 97久久精品午夜一区二区| 超清无码熟妇人妻AV在线电影| 国产精品白丝AV嫩草影院| 精品熟妇无码av免费久久| 美女裸体18禁免费网站| 人妻无奈被迫屈辱1-9| 无码高潮爽到爆的喷水视频APP | 欧美变态口味重另类在线视频| 日韩一区二区无码视频| 亚洲国产精品美女久久久久| 99RE6在线视频精品免费| 国产成人精品午夜视频| 久久精品亚洲精品无码金尊 | 久久久久久久性潮| 人妻系列综合第一页| 亚洲AV无码国产在丝袜线观看| 九九久久精品国产| 国内精品久久久久久久97牛牛| 国产护士在线视频XXXX免费| 另类小说激情婷婷久久| 中文字幕亚洲综合久久2020| 无码人妻AⅤ一区二区三区| 欧美人与牲动交XXXⅩ| 久久婷婷五月综合成人D啪| 精品国精品国产自在久国产应用 | 国产美女裸体无遮挡免费视频高潮| 久久AV无码精品人妻系列| 青草青草久热精品视频国产4 | 国产二级一片内射视频播放| 久久久综合亚洲色一区二区三区| 日日摸夜夜添狠狠添欧美| 亚洲日本VA中文字幕久久道具| 波多野结衣av在线| 久久大香伊蕉在人线免费AV | 麻豆成人传媒一区二区| 双方夫妻一起互动交流做 | 久久久久精品电影一区二区三区 | 大荫蒂又大又长又硬又紧| 久久久99精品成人片| 少妇兽交PWWW综合网| 又黄又爽又无遮挡免费的网站| 国产成人AV乱码在线观看| 免费的最近直播比较火的黄台| 无码人妻精品一区二区三区夜夜嗨 | 日本三级强伦姧护士HD| 亚洲综合一区国产精品| 女人高潮娇喘抽搐喷水动态视频| WWW国产无套内射COM| 黑人玩弄漂亮少妇高潮大叫| 人人妻人人妻人人人人妻| 亚洲中文字幕无码人在线 | 欧美 日韩 国产 成人 在线观| 亚洲AVT无码天堂网| WWW夜片内射视频在观看视频| 精品无人区无码乱码大片国产 | 成年女人粗暴毛片免费观看| 久久亚洲精品成人无码网站夜色| 无码国产成人久久| JULIA无码中文字幕一区| 久久不见久久见中文字幕免费| 熟女无套高潮内谢吼叫免费| 99在线精品免费视频九九视| 精品国产一区二区三区AV片| 熟女高潮喷水一区二区三区| AV无码东京热亚洲男人的天堂 | 亚洲熟妇色XXXXXX爽| 国产成人亚洲欧美二区综合| 人妻少妇看A偷人无码精品| 夜色爽爽影院18禁妓女影院| 国产无人区一码二码三码MBA| 丰满爆乳一区二区三区| 老少配XXOO老少配| 亚洲精品无码久久久久牙蜜区| 国产 | 欧洲野花视频欧洲1| 欧美极品JIZZHD欧美| 亚洲制服无码一区二区三区| 国产在线精品无码AV不卡顿| 视频一区二区三区日韩| JAPANESE五十路熟女| 麻花传媒剧国产MV高清播放| 亚洲精品AⅤ无码精品| 国产看黄网站又黄又爽又色| 色噜噜狠狠一区二区三区| AV优选天堂污污污成人亚洲 | 孩交乱子XXXX高清影视| 婷婷人人爽人人爽人人片| 成人H动漫无码网站久久| 欧美人妻兽交V1DE0S| 在线观看成人片韩剧| 精品无码一区二区三区水蜜桃| 小少妇BBBBBBBBBBBB| 国产成人久久久精品二区三区 | 亚洲精品乱码久久久久久按摩| 国产精品无码一二区免费| 四虎影视国产精品久久 | 日本护士HD人XXXX| GAY男同帅哥网站在线观看| 老湿机影院免费观看| 亚洲中文字幕人妻| 精品人妻少妇一区二区| 亚洲AV永久无码精品表情包| 国产网红在线_电影频道| 无码人妻精品一区二区蜜桃视频| 高清拍拍拍无挡国产精品| 三个男人躁我一个爽| 成年午夜免费韩国做受| 人妻少妇AV中文字幕乱码| FREE性欧美精品VIDEOS| 欧美极度另类XXⅩOO| 99精品视频九九精品视频| 男女24式动态图| 99国产精品久久久蜜芽 | 无码精品人妻一区二区三区漫画 | 免费人妻精品一区二区三区| 中文字幕日韩一区二区三区不卡| 两个男用舌头到我的蕊花| 在线播放国产一区二区三区| 两个女人互添下身爽舒服小说| 中日韩人妻中文字幕视频在线| 美女脱精光手不挡图片| 2021最新国产在线人成| 女人被弄高潮视频免费| A级精品国产片在线观看| 亲子伦AV一区的三区| 吃花核心舌头在里面旋转| 熟女CHACHACHA性少妇| 国产剧情麻豆女教师在线观看| 亚洲AV成人综合网伊人APP| 精产国品一二三产区区别在线观看 | 人妻系列无码专区69影院| 粗大黑人巨茎大战欧美成人免费看| 色哟哟网站在线观看| 国产精品精华液网站| 午夜国产精品一二三区无码小说| 国产又黄又爽又刺激的免费网址| 亚洲国产区男人本色在线观看| 久久精品国产亚洲AV麻豆网站| 尤物娇妻被NP高H| 欧美巨大XXXX做受| 成本人H无码播放私人影院| 私人影院无在线码免费| 国产一二三四2021精字窝| 亚洲色成人网站WWW永久下载 | 97人人添人澡人人爽超碰| 秋霞免费理论片在线观看| 国产Chinese男男GayGay网站 | 日日澡夜夜澡人人高潮| 国产精品麻豆VA在线播放| 亚洲国产成人片在线观看无码| 久久久久久久无码高潮| AA丁香综合激情| 色婷婷色综合激情国产日韩| 国产无遮挡裸体免费视频| 亚洲一线二线三线品牌精华液 | 无码熟妇人妻AV在线影片免费| 护士趴下光屁股翘臀被打的作文| 亚洲中文字幕AⅤ天堂| 女人的选择HD中字| 丁香婷婷激情综合俺也去| 亚洲AVTV永久综合在线| 狼人视频国产在线视频WWW色| VIDEOS性饥渴| 无遮挡啪视频APP| 久久人人妻人人做人人爽| 锕锕锕锕锕锕锕好痛免费网址| 无码人妻精品内射一二三AV| 久久精品中文字幕有码| JEAⅠOUSVUE成熟HD| 无码一区二区三区免费| 久久人妻无码一区二区三区AV| 拔萝卜日本视频在线观看免费| 性欧美VIDEOFREE高清成| 噜噜噜亚洲色成人网站∨| 成人全部免费的A毛片在线看 | 少妇饥渴偷公乱第一章全文| 精东传媒2021精品密友第一季| 97久久超碰极品视觉盛宴| 无码A级毛片免费视频内谢5J| 久久精品国产99久久无毒不卡| 暴躁少女CSGO图片| 亚洲AV无码成人精品涩涩| 女人扒下裤让男人桶到爽| 国产精品日韩欧美一区二区三区 | 邻居把我弄的高潮三次面舞| 畜禽CROPROATION| 亚洲欧美色国产综合| 人人爽人人模人人人爽人人爱| 国精产品一品二品国精| 97人妻人人揉人人躁人人| 无码熟妇人妻AV在线电影| 美国MACBOOKPRO日本| 国产精品无码成人午夜电影| 50岁毛多熟女一区二区三区| 性色AV一区二区三区天美传媒|