java集合框架總結(jié)

ArrayList:

Object[] 數(shù)組實現(xiàn)
default_capacity = 10
擴容: newCapacity = oldCapacity + (oldCapacity >> 1), 最大值為Integer.MAX_VALUE
modCount: 用于迭代器的并發(fā)修改檢查令境, 迭代過程中若發(fā)現(xiàn)其他線程修改了鏈表,拋出ConCurrentModificationException

LinkedList:

沒有什么特別要記的

HashMap:

數(shù)組 + 鏈表 + 紅黑樹(jdk1.8)
default_capacity = 1 << 4
terrfiy_threshold = 8, 超過此值鏈表轉(zhuǎn)為紅黑樹
loadFactor = 0.75
插入位置:table[(h = hash(Object o)) & capacity - 1]
擴容: 2倍, 發(fā)生在size超過threshold(capacity * loadfactor)
擴容后重hash: 對于某條鏈表上的node來講益涧, 新位置有兩種情況: if e.hash & oldCapacity == 0,newPosition = oldPosition; else newPosition = oldPosition + oldCapacity;

LinkedHashMap extends HashMap:

Entry extends Node,在Node基礎(chǔ)上添加了before,after指針逐哈,維護一條帶頭尾結(jié)點的雙向鏈表吗冤,鏈表有兩種順序:訪問順序,最近訪問的在鏈表尾部嘲碧; 插入順序

PriorityQueue:

Object[]數(shù)組 + 最大堆實現(xiàn)
對于隊列數(shù)據(jù)要求數(shù)據(jù)自身實現(xiàn)Comparable接口稻励,或者創(chuàng)建隊列時傳入Comparator,目的都是為了可以對數(shù)據(jù)進行比較
插入數(shù)據(jù)時愈涩, 先插到最后望抽, 然后siftUp調(diào)整堆, 取出數(shù)據(jù)時履婉,移除堆頂數(shù)據(jù)煤篙,然后將最后一個數(shù)據(jù)放置堆頂,siftDown調(diào)整堆
擴容: newCapacity = oldCapacity + (oldCapacity < 64) ? (oldCapacity + 2) : (oldCapacity >> 1)

ThreadLocal<T>:

Thread內(nèi)部維護一個ThreadLocalMap對象毁腿, 這個Map的key是ThreadLocal辑奈, 值是線程需要存的數(shù)據(jù)。ThreadLocal其實就是線程的管家已烤,所有線程私有的東西都可以交給它來管理鸠窗。如果碰到共享的數(shù)據(jù),那么ThreadLocal可以為線程保存一份私有副本胯究,這樣就可以避免使用鎖而提高性能了稍计。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市裕循,隨后出現(xiàn)的幾起案子丙猬,更是在濱河造成了極大的恐慌,老刑警劉巖费韭,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件茧球,死亡現(xiàn)場離奇詭異,居然都是意外死亡星持,警方通過查閱死者的電腦和手機抢埋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來督暂,“玉大人揪垄,你說我怎么就攤上這事÷呶蹋” “怎么了饥努?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長八回。 經(jīng)常有香客問我酷愧,道長驾诈,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任溶浴,我火速辦了婚禮乍迄,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘士败。我一直安慰自己闯两,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布谅将。 她就那樣靜靜地躺著漾狼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪饥臂。 梳的紋絲不亂的頭發(fā)上逊躁,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天,我揣著相機與錄音擅笔,去河邊找鬼志衣。 笑死,一個胖子當(dāng)著我的面吹牛猛们,可吹牛的內(nèi)容都是我干的念脯。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼弯淘,長吁一口氣:“原來是場噩夢啊……” “哼绿店!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起庐橙,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤假勿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后态鳖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體转培,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年浆竭,在試婚紗的時候發(fā)現(xiàn)自己被綠了浸须。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡邦泄,死狀恐怖删窒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情顺囊,我是刑警寧澤肌索,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站特碳,受9級特大地震影響诚亚,放射性物質(zhì)發(fā)生泄漏晕换。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一亡电、第九天 我趴在偏房一處隱蔽的房頂上張望届巩。 院中可真熱鬧硅瞧,春花似錦份乒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至枣接,卻和暖如春颂暇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背但惶。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工耳鸯, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人膀曾。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓县爬,卻偏偏與公主長得像,于是被迫代替她去往敵國和親添谊。 傳聞我的和親對象是個殘疾皇子财喳,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 一耳高、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對于byte類型而言...
    龍貓小爺閱讀 4,259評論 0 16
  • 在熱氣騰騰的車廂 人與人緊密相挨 像欲待下鍋的餃子 又像竹筍般矗立的冰雕 唯有你與眾不同 你始終保持鮮艷微笑 還散...
    江小昨閱讀 171評論 3 5
  • 第十三話 冒險 “Ok!搞定!這下買定離手所踊,沒得反悔了你泌枪。”電話那頭夸張的笑聲秕岛,讓趙麗穎可以想象得到某人笑得是有多...
    等猴抱兔閱讀 787評論 1 17
  • 1碌燕、 她是那一株曼陀羅,是生長在曼陀山莊的那一朵遺世之花瓣蛀。 卿本佳人陆蟆,本應(yīng)該有一個好的運數(shù),可是她偏偏為情負累惋增,既...
    顧秋水閱讀 5,081評論 34 42
  • 文/劉西楚 有一類藝術(shù)作品呈現(xiàn)的是一片混亂的人類經(jīng)驗像棘。它們既不求磨光那些粗糙的棱角,也不像多數(shù)影片那樣回避現(xiàn)實生活...
    劉西楚閱讀 370評論 2 2