前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java——类集框架:Map集合的详解及应用举例

Java——类集框架:Map集合的详解及应用举例

作者头像
Winter_world
发布2020-09-25 10:09:07
7620
发布2020-09-25 10:09:07
举报

1、Map接口的定义

Map保存的是二元偶对象,简单说就是两个值,key和value。使用中可以通过key查找到value数据,使用Map可以方便用户查询。

Map中定义的关键操作方法:

名称

作用

public V put(K key, V value)

向集合中追加数据

public V get(K key)

根据key返回对应的value数据

public Set<K> keySet()

返回Map中的所有key

public Set<Map.Entry<K,V>> entrySet()

将Map集合转换为Set集合

    Map接口中有两个常用的子类:HashMap、Hashtable,通过这两个子类进行Map的实例化。

2、HashMap子类

HashMap接口在JDK1.2中开始定义,开发中应用的最多的一个子类。

 【举例】:Map的基本操作

代码语言:javascript
复制
        Map<String,Integer> map = new HashMap<>();
        map.put("张三",10);
        map.put("李四",20);
        map.put("赵五",18);
        System.out.println(map);

Map集合的数据是无序的,也不需进行排序,因为Map集合应用的目的不是为了输出,是为了查询使用。

Map可以保存null值,但这种输出的操作形式并不理想,因为Map主要就是用于查询使用,key不存在值,返回为null。

【举例】Map接口中i当以有keySet方法,可以获取全部key的信息:

代码语言:javascript
复制
        Map<String,Integer> map = new HashMap<>();
        map.put("张三",10);
        map.put("李四",20);
        map.put("赵五",18);
        map.put(null,0);
        map.put("empty",null);
        Set<String> set =map.keySet();
        Iterator iterator = set.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }

注意:如果Map集合中使用重复的key保存,则旧内容将被新内容覆盖。

3、Hashtable子类(旧的子类)

Hashtable与Vctor、Enumeration都是JDK1.0推出,1.2后重新设计,1.2后其也变成了Map的子类。HashMap与Hashtable的具体区别是什么呢?(区别类似于ArrayList与Vector):

序号

区别点

HashMap(90%)

Hashtable(20%)

1

推出时间

JDK1.2

JDK1.0

2

性能

异步处理,性能较高

同步处理,性能较低

3

安全性

非线程安全的操作

线程安全操作

4

保存null

key或value允许为null

不允许为null

不允许为null

不允许为null

开发中无法回避null的问题,所以最好使用HashMap.

4、排序的子类:TreeMap

了解即可,该子类保存的数据可以实现key排序操作,TreeMap 的value可以保存null,Key不可以保存null,key的排序一定是参照comparable接口的执行结果。

代码语言:javascript
复制
        Map<Integer,String> map = new TreeMap<>();
        map.put(1,"大哥");
        map.put(3,"老三");
        map.put(2,"老二");

        System.out.println(map);

5、利用Iterator输出Map集合

在Collection接口中会提供iterator()方法,可以直接为Iterator接口实例化,但Map接口未提供,该如何利用Iterator进行输出呢?首先针对Map与Collection数据保存过程做一个比较:

要利用Iterator输出Map集合 数据,首先看下Map.Entry接口,其包括的方法:

  • 取得包装的key:public K getKey();
  • 取得包装的value:public V getValue();

那么,Map接口基于Iterator输出的步骤如下:

1)利用Map接口中的entrySet方法将Map集合变为Set集合;

2)Set集合定义了iterator()方法,可以实例化Iterator接口;

3)利用Iterator接口迭代输出,找出每个Map.Entry接口对象,利用getKey()与getValue()方法获取对应值。

【举例】:利用Iterator输出Map集合

代码语言:javascript
复制
        Map<String,Integer> map = new HashMap<>();
        map.put("张三",10);
        map.put("李四",20);
        map.put("赵五",18);
        Set<Map.Entry<String,Integer>> set =  map.entrySet();
        Iterator<Map.Entry<String,Integer>> iterator = set.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }
代码语言:javascript
复制

6、自定义Map中的key

不再写代码举例,既然涉及查找,就涉及到对象是否想等比较,自定义的key  类 要覆写hashCode()、equals()方法,否则查找无效。实际开发过程中,Map的核心功能就是查找,优先考虑的key类型为Interger、String类型,这两个都已经覆写了hashCode()、

equals(),写实现了Comparable接口,因此在开发中不建议使用自定义类型。

7、总结

1)Mapj接口主要进行查询应用,常用的子类为HashMap,可以保存null;

2)Map使用Iterator输出的步骤方法;

3)建议使用系统类String、Integer作为key类型,不使用自定义的key。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-03-14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、Map接口的定义
  • 2、HashMap子类
  • 3、Hashtable子类(旧的子类)
  • 4、排序的子类:TreeMap
  • 5、利用Iterator输出Map集合
  • 6、自定义Map中的key
  • 7、总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档