Java之集合(七)Map

  转载请注明源出处:http://www.cnblogs.com/lighten/p/7327216.html

1.前言

  按照顺序,本章本是要对Set的相关类进行介绍及讲解的。但是对于其实现有所了解的都应该知道,Set本身的代码十分简单,其实现都是通过Map来实现的,所以本章介绍一下Java中的Map接口及抽象类。

2.Map接口

  除去JDK8添加的新特性不看,Map中定义的方法如下:

  1.size():返回键值对个数

  2.isEmpty():判断是否为空

  3.containsKey(key):键的集合中是否存在所给键

  4.containsValue(value):值的集合中是否存在所给值

  5.get(key):获取指定键的值

  6.put(key,value):存入一对键值对

  7.remove(key):移除指定键的键值对

  8.putAll(Map):将所给的键值对全部存入

  9.clear():清除所有的键值对

  10.keySet():将所有的键值以Set集合返回

  11.values():返回所有值的集合

  12.entrySet():返回键值对的Set集合

  13.getOrDefault():如果该键存在(哪怕对应值为null),返回其值,否则返回所给默认值

  14.putIfAbsent():如果所给键不存在或者存在对应的值为null,重新设置,否则返回其值

  15.remove(key,value):如果所给的值与该键对应的值不相等就不移除该键。

  16.replace(key, oldValue, newValue):如果键所对应的值与所给旧值相等就用新值替换。

  17.replace(key, value):如果该键存在,就用新值替换。并返回之前的值。

  上述所有方法,从getOrDefault就使用了JDK8的新特性,能在接口中实现默认方法。

3.Entry

  Entry是map实现的一个关键数据结构(就是一个键值对对象),关于Entry的接口定义如下:

  1.getKey():获取键值对的键

  2.getValue():获取键值对的值

  3.setValue():设置键值对的值

  后面的方法都是JDK8相关内容,不进行讲解。

4.AbstractMap

  抽象类的实现并没有多大参考价值,就像其它集合一样,大部分子类都覆盖了抽象父类的相关方法。

  size方法就比较很有意思。其使用的是entrySet的大小,而开篇也说了Set是借助Map实现的,其实际上调用的又是Map的size()方法。如果按抽象父类这种写法,那么就死循环了。同样的还有clear方法。

 

   containsValue或者key都是通过entrySet拿到所有的键值对遍历实现的,实现和其它集合的抽象父类基本一致。之后的get,remove等方法都是一样的原理。其余的方法也不再一一叙述,如果前面几章集合的类认真学习过,这个基本是一样的套路。

posted @ 2017-08-09 19:14  dark_saber  阅读(605)  评论(0编辑  收藏  举报