Java集合框架(七)Map接口

Map是什么

Map用來存放鍵值對數(shù)據(jù)翎朱,可以看做是鍵值對的集合。
Map不能包含重復的鍵,也就意味著每個鍵只能映射到最多一個值痹换。Map沒有規(guī)定不能存放為null的值恰梢。
Java平臺提供三種通用的Map實現(xiàn)類:HashMap, TreeMap, LinkedHashMap容握。三者的行為和性能可以類比HashSet,TreeSet,LinkedHashSet芋膘。

Map提供的接口

作為一個集合旦袋,自然是需要提供增刪改查這類接口祭钉。來看看Map都提供了什么:

  • 添加修改操作:
    // 向Map中添加或者更新值瞄沙。返回先前映射的元素,或者null慌核,如果不存在距境。
    public V put(K key, V value);
    public void putAll(Map<? extends K,? extends V> map);
    
    對于put操作,如果Map已經(jīng)包含了當前的key垮卓,則會用更新原有值為新的value垫桂。
  • 刪除操作:
    // 返回被刪除的元素,或者如果該元素不存在則返回null
    public V remove(Object key);
    public void clear();
    
  • 查詢操作:
    // 返回Map中鍵值對個數(shù)
    public int size();
    // 返回key映射的值粟按,如果不存在則返回null
    V get(Object key);
    /**
     * 返回包含的鍵的集
     * 注意:返回的Set不支持添加操作诬滩。并且修改返回的Set或者原有Map將會相互影響
     */ 
    public Set<K> keySet();
    /**
     * 返回包含的所有值的集合
     * 注意:修改原有Map或者返回的集合將會相互影響。
     * 返回的集合支持remove, removeAll, retainAll以及clear操作灭将,不支持add, addll操作碱呼。
     */ 
    public Collection<V> values();
    
    /** 
     * 返回一個包含所有映射內容的集形式,每條映射內容保存于Entry中
     * 同樣修改返回的Set或者原有Map將會相互影響 
     */
    public Set<Map.Entry<K,V>> entrySet();
    
  • 測試操作:
    public boolean containsKey(Object key);    
    public boolean containsValue(Object value);
    public boolean isEmpty();
    public boolean equals(Object object);
    
  • 其他:
    public int hashCode();
    

查詢操作里面宗侦,keySet()愚臀,entrySet()values()方法返回了Map的集合視圖矾利,可以方便使用Collection接口形式進行操作姑裂。

另外馋袜,所有的通用Map實現(xiàn)都提供將Map作為參數(shù)的構造函數(shù),類似Collection舶斧,這將很方便的用于拷貝生成一個新的Map實現(xiàn)欣鳖,而不用考慮以前的實現(xiàn)類型。

基本操作的例子

下面的例子用來統(tǒng)計參數(shù)表中的每個詞出現(xiàn)的次數(shù)茴厉,并保存在Map中泽台。

package com.shane.collection;

import java.util.HashMap;
import java.util.Map;

/**
 * Created by Shane on 2016/6/25.
 */
public class Freq {
    public static void main(String[] args) {
        Map<String, Integer> m = new HashMap<String, Integer>();

        // Initialize frequency table from command line
        for (String a : args) {
            Integer freq = m.get(a);
            m.put(a, (freq == null) ? 1 : freq + 1);
        }

        System.out.println(m.size() + " distinct words:");
        System.out.println(m);
    }
}

上面唯一需要注意的就是通過判斷freq是否等于null,來確定是不是第一次添加矾缓,因為等Map中沒有包含某個key時怀酷,返回的值為null。

在命令行下嗜闻,切換到編譯后的class文件最頂層蜕依,執(zhí)行下面的命令:

java com.shane.collection.Freq if it is to be it is up to me to delegate

注意,這里com.shane.collectionFreq類所在的包琉雳。

測試結果如下:

// HashMap
8 distinct words:
{delegate=1, be=1, me=1, is=2, it=2, to=3, up=1, if=1}

// TreeMap
8 distinct words:
{be=1, delegate=1, if=1, is=2, it=2, me=1, to=3, up=1}

// LinkedHashMap
8 distinct words:
{if=1, it=2, is=2, to=3, be=1, up=1, me=1, delegate=1}

通過傳入不同的Map實現(xiàn)样眠,可以得到不同的結果〈渲猓可以看到TreeMap以字母順序返回結果檐束,LinkedHashMap則以第一次出現(xiàn)的單詞的先后順序返回。這也印證了它們各自的特性束倍。

多值Map(Multimaps)

這里指的是一個Map厢塘,可以映射每個key到多個values。Java集合框架并沒有包含一個接口用于多值Map肌幽,主要是因為這個并不是那么常用晚碾。通常利用將一個key映射到一個List來達到多值映射的目的。
比如:

Map<String, List<String>> = new HashMap<String, List<String>>;
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末喂急,一起剝皮案震驚了整個濱河市格嘁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌廊移,老刑警劉巖糕簿,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異狡孔,居然都是意外死亡懂诗,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進店門苗膝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來殃恒,“玉大人,你說我怎么就攤上這事±胩疲” “怎么了病附?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長亥鬓。 經(jīng)常有香客問我完沪,道長,這世上最難降的妖魔是什么嵌戈? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任覆积,我火速辦了婚禮,結果婚禮上熟呛,老公的妹妹穿的比我還像新娘宽档。我一直安慰自己,他們只是感情好惰拱,可當我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著啊送,像睡著了一般偿短。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上馋没,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天昔逗,我揣著相機與錄音,去河邊找鬼篷朵。 笑死勾怒,一個胖子當著我的面吹牛,可吹牛的內容都是我干的声旺。 我是一名探鬼主播笔链,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼腮猖!你這毒婦竟也來了鉴扫?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤澈缺,失蹤者是張志新(化名)和其女友劉穎坪创,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體姐赡,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡莱预,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了项滑。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片依沮。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出悉抵,到底是詐尸還是另有隱情肩狂,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布姥饰,位于F島的核電站傻谁,受9級特大地震影響,放射性物質發(fā)生泄漏列粪。R本人自食惡果不足惜审磁,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望岂座。 院中可真熱鬧态蒂,春花似錦、人聲如沸费什。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鸳址。三九已至瘩蚪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間稿黍,已是汗流浹背疹瘦。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留巡球,地道東北人言沐。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像酣栈,于是被迫代替她去往敵國和親险胰。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理矿筝,服務發(fā)現(xiàn)鸯乃,斷路器,智...
    卡卡羅2017閱讀 134,657評論 18 139
  • 一、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對于byte類型而言...
    龍貓小爺閱讀 4,265評論 0 16
  • 1. Java基礎部分 基礎部分的順序:基本語法陈辱,類相關的語法奖年,內部類的語法,繼承相關的語法沛贪,異常的語法陋守,線程的語...
    子非魚_t_閱讀 31,633評論 18 399
  • java筆記第一天 == 和 equals ==比較的比較的是兩個變量的值是否相等震贵,對于引用型變量表示的是兩個變量...
    jmychou閱讀 1,500評論 0 3
  • 網(wǎng)上兼職可信嗎?大家都不信,所以我不信水评,哈哈哈哈猩系,這就是很實在的從眾反應咯。 暑假在家中燥,雖說不急用錢...
    你是我18歲開始的夢閱讀 135評論 0 0