Map (映射)一 一對(duì)應(yīng)的關(guān)系 一對(duì)一、一對(duì)多

Map 是一種把鍵對(duì)象和值對(duì)象進(jìn)行關(guān)聯(lián)的容器羡滑, 而一個(gè)值對(duì)象又可以是一個(gè)Map, 依次類推菇爪,這樣就可形成一個(gè)多級(jí)映射算芯。

想想學(xué)習(xí)英語(yǔ)使用的詞典軟件,輸入英文(key)后凳宙,軟件會(huì)顯示出對(duì)應(yīng)的中文(value)熙揍。Map就是在內(nèi)存中的這種結(jié)構(gòu)。

Key(鍵):

  1. 和 set— 樣氏涩,鍵對(duì)象不允許重復(fù)届囚,這是為了保持查找結(jié)果的一致性。 如果有兩個(gè)鍵對(duì)象一樣是尖, 那你想得到那個(gè)鍵對(duì)象所對(duì)應(yīng)的值對(duì)象時(shí)就有問(wèn)題了意系。
  2. 在使用過(guò)程中某個(gè)鍵所對(duì)應(yīng)的值對(duì)象可能會(huì)發(fā)生變化, 這時(shí)會(huì)按照最后一次修改的值對(duì)象與鍵對(duì)應(yīng)(就是key同一個(gè)key有多次值綁定析砸,最后一個(gè)就會(huì)覆蓋之前的)
  3. 可以使用 null 作為 Key

Value(值):

  1. 值對(duì)象沒(méi)有唯一性的要求昔字, 你可以將任意多個(gè)鍵都映射到一個(gè)值對(duì)象上, 這不會(huì)發(fā)生任何問(wèn)題( 不過(guò)對(duì)使用卻可能會(huì)造成不便首繁, 你不知道你得到的到底是那一個(gè)鍵所對(duì)應(yīng)的值對(duì)象作郭,所以請(qǐng)不要這樣做)
  2. 可以使用 null 作為 Value

Map 有兩種比較常用的實(shí)現(xiàn): HashMap 和 TreeMap

常用的方法

方法名 說(shuō)明
put(key , value) 儲(chǔ)存數(shù)據(jù)
get(key) 通過(guò)key得到值
remove(key) 通過(guò)key刪除對(duì)應(yīng)的值(key當(dāng)然也會(huì)刪除)
entrySet() 獲取Map所有的Key,返回一個(gè)Set集合
values() 獲取Map所有的value弦疮,返回一個(gè)List 集合
containsKey(key) 判斷Map中是否有輸入的參數(shù):key
containsValue(value) 判斷Map中是否有輸入的參數(shù):value
size() 判斷Map中數(shù)據(jù)的總數(shù)
clear() 清空Map中所有的數(shù)據(jù)
isEmpty() 判斷Map中是否有數(shù)據(jù)

HashMap

HashMap 用到了哈希碼的算法夹攒, 以便快速查找一個(gè)鍵。

public static void main(String[] args) {

    HashMap<String, String> zsInfo = new HashMap<>();

    zsInfo.put("name", "張三");
    zsInfo.put("height", "173CM");
    zsInfo.put("sex", "男性");

    for (Map.Entry<String, String> info : zsInfo.entrySet()) {
        System.out.println( info );
    }
}
負(fù)載因子胁塞,當(dāng)容量使用到75%時(shí)咏尝,觸發(fā)擴(kuò)容的操作
DEFAULT_LOAD_FACTOR  = 0.75    負(fù)載因子 = 0.75
DEFAULT_INITIAL_CAPACITY = 16  默認(rèn)的初始化容量=16,必須是2的整數(shù)次冪啸罢,原因是便于Hash運(yùn)算编检,提高效率
TREEIFY_THRESHOLD = 8  樹化_閾值 = 8  當(dāng)長(zhǎng)度大于8時(shí),鏈表的查詢會(huì)變慢扰才,優(yōu)化為樹

TreeMap

TreeMap 是對(duì)鍵按序存放允懂, 因此它便有一些擴(kuò)展的方法, 比如 firstKey() 衩匣、lastKey() 等蕾总, 可以從TreeMap 中指定一個(gè)范圍以取得其子Map

public static void main(String[] args) {

    TreeMap<String, String> tree = new TreeMap<>();

    tree.put("name", "Jack");
    tree.put("age", "22");
    tree.put("身高", "173");
    tree.put("sex", "man");
    tree.put("體重", "70KG");

    System.out.println("-------------------");
    for (Map.Entry<String, String> entry : tree.entrySet()) {
        System.out.println( entry );
    }
    System.out.println("-------------------");

    System.out.println("firstKey = "+ tree.firstKey());
    System.out.println("firstEntry = "+ tree.firstEntry());
    System.out.println("lastKey = "+ tree.lastKey());
    System.out.println("lastEntry = "+ tree.lastEntry());

}

樹:紅黑樹

性質(zhì)1. 結(jié)點(diǎn)是紅色或黑色。
性質(zhì)2. 根結(jié)點(diǎn)是黑色琅捏。
性質(zhì)3. 所有葉子都是黑色生百。(葉子是NIL結(jié)點(diǎn))
性質(zhì)4. 每個(gè)紅色結(jié)點(diǎn)的兩個(gè)子結(jié)點(diǎn)都是黑色。(從每個(gè)葉子到根的所有路徑上不能有兩個(gè)連續(xù)的紅色結(jié)點(diǎn))
性質(zhì)5. 從任一節(jié)結(jié)點(diǎn)其每個(gè)葉子的所有路徑都包含相同數(shù)目的黑色結(jié)點(diǎn)柄延。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蚀浆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蜡坊,老刑警劉巖杠输,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赎败,死亡現(xiàn)場(chǎng)離奇詭異秕衙,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)僵刮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門据忘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人搞糕,你說(shuō)我怎么就攤上這事勇吊。” “怎么了窍仰?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵汉规,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我驹吮,道長(zhǎng)针史,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任碟狞,我火速辦了婚禮啄枕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘族沃。我一直安慰自己频祝,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布脆淹。 她就那樣靜靜地躺著常空,像睡著了一般。 火紅的嫁衣襯著肌膚如雪盖溺。 梳的紋絲不亂的頭發(fā)上漓糙,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音咐柜,去河邊找鬼兼蜈。 笑死,一個(gè)胖子當(dāng)著我的面吹牛拙友,可吹牛的內(nèi)容都是我干的为狸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼遗契,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼辐棒!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤漾根,失蹤者是張志新(化名)和其女友劉穎泰涂,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體辐怕,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡逼蒙,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了寄疏。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片是牢。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖陕截,靈堂內(nèi)的尸體忽然破棺而出驳棱,到底是詐尸還是另有隱情,我是刑警寧澤农曲,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布社搅,位于F島的核電站,受9級(jí)特大地震影響乳规,放射性物質(zhì)發(fā)生泄漏形葬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一驯妄、第九天 我趴在偏房一處隱蔽的房頂上張望荷并。 院中可真熱鬧,春花似錦青扔、人聲如沸源织。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)谈息。三九已至,卻和暖如春凛剥,著一層夾襖步出監(jiān)牢的瞬間侠仇,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工犁珠, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逻炊,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓犁享,卻偏偏與公主長(zhǎng)得像余素,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子炊昆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

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

  • Map接口 Map是 一個(gè)鍵值對(duì)的集合桨吊。也就是說(shuō)威根,一個(gè)映射不能包含重復(fù)的鍵,每個(gè)鍵最多映射到一個(gè)值视乐。該接口取代了D...
    wame100閱讀 780評(píng)論 0 0
  • 一洛搀、當(dāng)兩個(gè)對(duì)象的 hashCode 相同會(huì)發(fā)生什么? 因?yàn)?hashCode 相同佑淀,不一定就是相等的(equals...
    Djbfifjd閱讀 714評(píng)論 1 11
  • Map接口 概述:1.Map與List留美、Set接口不同,它是由一系列鍵值對(duì)組成的集合渣聚,提供了key到Value的映...
    jadefly閱讀 331評(píng)論 0 0
  • Map 我們都知道 Map 是鍵值對(duì)關(guān)系的集合独榴,并且鍵唯一,鍵一對(duì)一對(duì)應(yīng)值奕枝。 關(guān)于 Map 的定義,大概就這些吧瓶堕,...
    Anonymous___閱讀 631評(píng)論 0 1
  • 我是黑夜里大雨紛飛的人啊 1 “又到一年六月隘道,有人笑有人哭,有人歡樂(lè)有人憂愁郎笆,有人驚喜有人失落谭梗,有的覺(jué)得收獲滿滿有...
    陌忘宇閱讀 8,543評(píng)論 28 53