List矩欠、Map财剖、Set的區(qū)別與聯系

一、結構特點

1癌淮、List和Set是存儲單列數據的集合躺坟,Map是存儲鍵值對這樣的雙列數據的集合;

2乳蓄、List中存儲的數據是有順序的咪橙,并且值允許重復;Map中存儲的數據是無序的,它的鍵是不允許重復的美侦,但是值是允許重復的产舞;Set中存儲的數據是無順序的,并且不允許重復菠剩,但元素在集合中的位置是由元素的hashcode決定易猫,即位置是固定的(Set集合是根據hashcode來進行數據存儲的,所以位置是固定的具壮,但是這個位置不是用戶可以控制的准颓,所以對于用戶來說set中的元素還是無序的)。

二棺妓、實現類

1攘已、List接口有三個實現類:

1.1 LinkedList

基于鏈表實現,鏈表內存是散列的涧郊,增刪快贯被,查找慢眼五;

1.2 ArrayList

基于數組實現妆艘,非線程安全,效率高看幼,增刪慢批旺,查找快;

1.3 Vector

基于數組實現诵姜,線程安全汽煮,效率低,增刪慢棚唆,查找慢暇赤;

2、Map接口有四個實現類:

2.1 HashMap

基于 hash 表的 Map 接口實現宵凌,非線程安全鞋囊,高效,支持 null 值和 null

鍵瞎惫;

2.2 HashTable

線程安全溜腐,低效,不支持 null 值和 null 鍵瓜喇;

2.3 LinkedHashMap

是 HashMap 的一個子類挺益,保存了記錄的插入順序;

2.4 SortMap 接口

TreeMap乘寒,能夠把它保存的記錄根據鍵排序望众,默認是鍵值的升序排序

3、Set接口有兩個實現類:

3.1 HashSet

底層是由 Hash Map 實現,不允許集合中有重復的值烂翰,使用該方式時需要重寫 equals()和 hash Code()方法叉袍;

3.2 LinkedHashSet

繼承于 HashSet,同時又基于 LinkedHashMap 來進行實現刽酱,底層使用的是 LinkedHashMap

三喳逛、區(qū)別

1. List 集合中對象按照索引位置排序,可以有重復對象棵里,允許按照對象在集合中的索引位置檢索對象润文,例如通過list.get(i)方法來獲取集合中的元素;

2. Map 中的每一個元素包含一個鍵和一個值殿怜,成對出現典蝌,鍵對象不可以重復,值對象可以重復头谜;

3. Set 集合中的對象不按照特定的方式排序骏掀,并且沒有重復對象,但它的實現類能對集合中的對象按照特定的方式排序柱告,例如 Tree Set 類截驮,可以按照默認順序,也可以通過實現 Java.util.Comparator< Type >接口來自定義排序方式际度。

四葵袭、補充

HashMap 和 HashTable

HashMap 是線程不安全的,HashMap 是一個接口,是 Map的一個子接口,是將鍵映射到值得對象,不允許鍵值重復,允許空鍵和空值;由于非線程安全, HashMap的效率要較 HashTable 的效率高一些.

HashTable 是線程安全的一個集合,不允許 null 值作為一個 key 值或者 Value 值;

HashTable 是 sychronize(同步化),多個線程訪問時不需要自己為它的方法實現同步,而 HashMap 在被多個線程訪問的時候需要自己為它的方法實現同步;

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市乖菱,隨后出現的幾起案子坡锡,更是在濱河造成了極大的恐慌,老刑警劉巖窒所,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鹉勒,死亡現場離奇詭異,居然都是意外死亡吵取,警方通過查閱死者的電腦和手機禽额,發(fā)現死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來海渊,“玉大人绵疲,你說我怎么就攤上這事〕家桑” “怎么了盔憨?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長讯沈。 經常有香客問我郁岩,道長婿奔,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上著觉,老公的妹妹穿的比我還像新娘。我一直安慰自己冰木,他們只是感情好,可當我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布笼恰。 她就那樣靜靜地躺著踊沸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪社证。 梳的紋絲不亂的頭發(fā)上逼龟,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天,我揣著相機與錄音追葡,去河邊找鬼腺律。 笑死,一個胖子當著我的面吹牛宜肉,可吹牛的內容都是我干的匀钧。 我是一名探鬼主播,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼崖飘,長吁一口氣:“原來是場噩夢啊……” “哼榴捡!你這毒婦竟也來了杈女?” 一聲冷哼從身側響起朱浴,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎达椰,沒想到半個月后翰蠢,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡啰劲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年梁沧,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蝇裤。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡廷支,死狀恐怖,靈堂內的尸體忽然破棺而出栓辜,到底是詐尸還是另有隱情恋拍,我是刑警寧澤,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布藕甩,位于F島的核電站施敢,受9級特大地震影響,放射性物質發(fā)生泄漏。R本人自食惡果不足惜僵娃,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一概作、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧默怨,春花似錦讯榕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至垃僚,卻和暖如春集绰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谆棺。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工栽燕, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人改淑。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓碍岔,卻偏偏與公主長得像,于是被迫代替她去往敵國和親朵夏。 傳聞我的和親對象是個殘疾皇子蔼啦,可洞房花燭夜當晚...
    茶點故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內容