简单回顾Map集合:

Map表示映射关系,以键值对的方式来保存数据。key和value一一对应。key是唯一的,不可重复,而value是可重复的,可以被多个key关联。虽然Map是放入两个数据,但是却以key作为操作对象,value只是作为key的关联值。

通过查看,会发现Set与Map的实现类很相似,Set实现类的底层操作就是用Map来实现的,Set集的特性就来自于Map。唯一不同的就是Map表示一种映射关系,一次存储2个数据,Set只能存储单一数据。

Map体系中的主要类:

  • HashMap:Map的典型实现,元素是无序且不可重复,这里的元素指的是key。
  • LinkedHashMap:以插入的次序作为排序状态,其他的和HashMap一致。
  • TreeMap:元素处于排序状态,可以使用自然排序也可以使用自定义排序,但key的类型必须一致,不然无法进行比较。
  • Properties:Key-Value都是String类型,用于加载属性文件。后续会说到。

Map的重要方法和特点:

常用方法就不概述,关于Map中方法的使用细节,例如replace()和remove()方法,如果返回值是Object,则会返回以前的value,返回值boolean,代表是否执行成功。重点需要了解entrySet()、keySet() 和values()的使用。
  • entrySet()___返回一个包含所有映射关系的Set集合,该Set集合的类型为Map.Entry,一般用于迭代键值对。Map.Entry是一个内部接口。
  • keySet()__..._返回该映射中所有key组成的Set集合。通过key获取键值对。
  • values()___._返回该映射中所有value值。
  • 这三个方法主要用于遍历键值对或直接获取value值,非常方便。但使用返回对象的方法时,会引发错误。代码示例和解析在最下面。

HashMap的代码示例

		HashMap hm = new HashMap();
//放入键值对
hm.put("cn", "中国");
hm.put(1, 100);
hm.put("us", "美国");
hm.put("Ja", "日本");
hm.put("时间", new Date());
hm.put(1, 200);//用同一个key关联别的value
System.out.println(hm); //等同于hm.toString() System.out.println("----根据key获取关联的值------");
System.out.println(hm.get("Ja"));
System.out.println(hm.get(1)); System.out.println("----替换指定的键值对-------");
System.out.println(hm.replace(1, "100"));//返回被替换的value
System.out.println(hm.replace("us", "美国","FuckYou"));//返回boolean,表示是否替换成功 System.out.println("----删除指定键值对----");
System.out.println(hm.remove("Ja"));//返回被删除的value
System.out.println(hm.remove("Ja","日本"));//返回是否成功删除
典型的Map实现,查看打印结果:元素是无序且不可重复的。在代码中放入两个相同的键值对,key只能有一个,如果value也不同,后来添加的value会覆盖原来的value。
 

LinkedHashMap简单示例

		LinkedHashMap lhm = new LinkedHashMap();
lhm.put(1,"B");
lhm.put(4,"A");
lhm.put(3,"C");
lhm.put(2,"D");
System.out.println(lhm);
//输出:{1=B, 4=A, 3=C, 2=D}

LinkedHashMap就是以插入次序作为排序状态,别的和HashMap一致。非常类似于HashSet与LinkedHashSet的关系。

 

entrySet() 和 keySet() 和 values()的代码示例

以TreeMap为例,演示entrySet()

		TreeMap tm = new TreeMap();
tm.put(1, "壹");
tm.put(3, "叁");
tm.put(6, "陆");
tm.put(7, "柒"); //使用迭代器来遍历元素
Set entrys = tm.entrySet();
Iterator it = entrys.iterator();
while(it.hasNext()) {
Map.Entry entry = (Map.Entry)it.next();//转换成Map.Entry类型
System.out.println(entry.getKey() +"-" + entry.getValue());
}

以TreeMap为例,演示keySet()

		TreeMap tm = new TreeMap();
tm.put(1, "壹");
tm.put(3, "叁");
tm.put(6, "陆");
tm.put(7, "柒"); Set k = tm.keySet();
Iterator it = k.iterator();
//mode 1
while(it.hasNext()) {
Object key = it.next();//获取key
System.out.println(key + "->" + tm.get(key));
}
//mode 2
for(Object key : k) {
System.out.println(key +"->" + tm.get(key));
}

以TreeMap为例,演示values()

		TreeMap tm = new TreeMap();
tm.put(1, "壹");
tm.put(3, "叁");
tm.put(6, "陆");
tm.put(7, "柒");
Collection value = tm.values();
for(Object v : value) {
System.out.println(v);
}
 

entrySet() keySet() 和 values()返回对象中的操作方法

		TreeMap tm = new TreeMap();
tm.put(1, "壹");
tm.put(3, "叁");
tm.put(6, "陆");
tm.put(7, "柒");
Set entry = tm.entrySet();
Set key = tm.keySet();
Collection value = tm.values(); // entry.add("A");引发不支持的操作异常
System.out.println(entry.remove(1));//false
System.out.println(entry.contains(3));//false System.out.println(key.remove(1));//true
System.out.println(key.contains(3));//true System.out.println(value.remove("壹"));//false

上面代码中,可以看出无论是返回Set对象还是Collection,添加元素都会引发不支持的操作异常。这是因为返回的集合对象本质上依然是对键值对操作。它们的不同之处:

entrySet()中有key和value,所以直接加入元素或者删除元素的方法都是无效的。keySet()中有key,可以对key进行操作,所以能使用remove()和equals(),所以返回true。

values()中只有value值,没有key,value值是没什么用的,所以values()方法也仅仅是获取所有value值方便。

相同之处:
方法中如果没有参数,不涉及到对键值对进行的操作,都是可以使用的。例如Iterator()、clear()、size()和isEmpty()等。
 

entrySet() 和 keySet() 和 values()的使用总结:

  • 一般只使用它们的迭代器,用于获取所有键值对。
  • 除了迭代器,对元素进行操作的方法不建议使用,容易出错。
  • 如果要高效遍历key-value,建议使用entrySet(),keySet()也可以做到,但需要通过key来获取value,多增加了一步。
  • 获取所有key就使用keySet(),获取所有value就使用values()

详解Map集合体系及方法entrySet、keySet、values的更多相关文章

  1. 详解 Map集合

    (请关注 本人"集合总集篇"博文--<详解 集合框架>) 首先,本人来讲解下 Map集合 的特点: Map集合 的特点: 特点: 通过 键 映射到 值的对象 一个 映射 ...

  2. java如何对map进行排序详解(map集合的使用)

    今天做统计时需要对X轴的地区按照地区代码(areaCode)进行排序,由于在构建XMLData使用的map来进行数据统计的,所以在统计过程中就需要对map进行排序. 一.简单介绍Map 在讲解Map排 ...

  3. Map集合中的方法

    Map集合中的方法: values() 方法 : 获取集合中的所有的值----没有键,没有对应关系, KeySet() 方法: 将Map中所有的键存入到set集合中.因为set具备迭代器.所有可以迭代 ...

  4. Spring框架系列(6) - Spring IOC实现原理详解之IOC体系结构设计

    在对IoC有了初步的认知后,我们开始对IOC的实现原理进行深入理解.本文将帮助你站在设计者的角度去看IOC最顶层的结构设计.@pdai Spring框架系列(6) - Spring IOC实现原理详解 ...

  5. ubuntu apache2配置详解(含虚拟主机配置方法)

    ubuntu apache2配置详解(含虚拟主机配置方法) 在Windows下,Apache的配置文件通常只有一个,就是httpd.conf.但我在Ubuntu Linux上用apt-get inst ...

  6. 详解Java中的clone方法

    详解Java中的clone方法 参考:http://blog.csdn.net/zhangjg_blog/article/details/18369201/ 所谓的复制对象,首先要分配一个和源对象同样 ...

  7. 分区工具parted的详解及常用分区使用方法【转】

    来源:http://blog.51cto.com/zhangmingqian/1068779 分区工具parted的详解及常用分区使用方法 一.         parted的用途及说明 概括使用说明 ...

  8. Ubuntu下安装JDK图文教程详解 jdk-java6-30 .bin 的处理方法

    Ubuntu下安装JDK图文教程详解 jdk-java6-30 .bin 的处理方法: https://blog.csdn.net/mingjie1212/article/details/485250 ...

  9. (转)linux命令详解之useradd命令使用方法

    linux命令详解之useradd命令使用方法 原文:http://blog.csdn.net/u011537073/article/details/51987121 Linux 系统是一个多用户多任 ...

随机推荐

  1. layui-table渲染不出来

    通过方法渲染 页面代码: <table id="tableList" lay-filter="clublist"></table> js ...

  2. Angular进阶教程二

    6.2自定义指令详解 angular的指令机制.angular通过指令的方式实现了HTML的扩展,增强后的HTML不仅长相焕然一新,同时也获得了很多强大的技能.更厉害的是,你还可以自定义指令,这就意味 ...

  3. kali 的端口扫描nmap

    输入“nmap+空格+“-O”+空格+IP地址或域名. 扫描所有TCP端口:输入“nmap+空格+“-sT”+空格+IP地址或域名” 扫描所有开放的UDP端口:输入“nmap+空格+”-sP”+空格+ ...

  4. 如何登陆FTP服务器下载文件

    原文:https://jingyan.baidu.com/article/f25ef254134bef482c1b82c2.html 方法/步骤1   1 第一种介绍的方法是从计算机(我的电脑)上登陆 ...

  5. c#之反射(Reflection)

    一.反射是什么 反射就是.Net FrameWork框架为我们提供的一个帮助类库,它可以读取我们通过编译后生成的dll和exe文件里面metadate的信息. 反射可以动态的加载dll和exe文件,动 ...

  6. [翻译] JTNumberScrollAnimatedView

    JTNumberScrollAnimatedView 本人视频教程系类   iOS中CALayer的使用 效果: Use JTNumberScrollAnimatedView for have a n ...

  7. EF学习之CodeFirst(二)--数据迁移

    使用CodeFirst时,如果Model发生改变的话,例如我们给User类里面新加个Sex属性,运行时会出现如下错误: 这时我们需要使用数据迁移来将model的改变同步更新到数据库中. 1.启用数据迁 ...

  8. 关于Oracle伪列rownum

    rownum列跟rowid列不一样,虽然同为表的伪列.但是rowid列是列的一个固定属性,而rownum列是结果集的一个排序.所以像如下查询是不会返回结果的:select rowid,rownum,e ...

  9. 枚举类型与位域枚举Enum

    一.概述 定义一个值类型,其中包含固定值集合.枚举类型变量可以是此集合中的任意一个或多个值.枚举使用enum关键字来声明,与类同级.枚举本身可以有修饰符,但枚举的成员始终是公共的,不能有访问修饰符.枚 ...

  10. Chapter 1 Secondary Sorting:Introduction

    开始学习<数据算法:Hadoop/Spark大数据处理技巧>第1-5章,假期有空就摘抄下来,毕竟不是纸质的可以写写画画,感觉这样效果好点,当然复杂的东西仍然跳过.写博客越发成了做笔记的感觉 ...