Java集合框架(七)Map接口

Map是什么

Map用来存放键值对数据,可以看做是键值对的集合。
Map不能包含重复的键,也就意味着每个键只能映射到最多一个值。Map没有规定不能存放为null的值。
Java平台提供三种通用的Map实现类: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已经包含了当前的key,则会用更新原有值为新的value
  • 删除操作:
    // 返回被删除的元素,或者如果该元素不存在则返回null
    public V remove(Object key);
    public void clear();
    
  • 查询操作:
    // 返回Map中键值对个数
    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实现都提供将Map作为参数的构造函数,类似Collection,这将很方便的用于拷贝生成一个新的Map实现,而不用考虑以前的实现类型。

基本操作的例子

下面的例子用来统计参数表中的每个词出现的次数,并保存在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文件最顶层,执行下面的命令:

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实现,可以得到不同的结果。可以看到TreeMap以字母顺序返回结果,LinkedHashMap则以第一次出现的单词的先后顺序返回。这也印证了它们各自的特性。

多值Map(Multimaps)

这里指的是一个Map,可以映射每个key到多个values。Java集合框架并没有包含一个接口用于多值Map,主要是因为这个并不是那么常用。通常利用将一个key映射到一个List来达到多值映射的目的。
比如:

Map<String, List<String>> = new HashMap<String, List<String>>;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,579评论 18 139
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,251评论 0 16
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,558评论 18 399
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 1,483评论 0 3
  • 网上兼职可信吗?大家都不信,所以我不信,哈哈哈哈,这就是很实在的从众反应咯。 暑假在家,虽说不急用钱...
    你是我18岁开始的梦阅读 132评论 0 0