Map 用于保存具有映射关系的数据,集合里会保存两组值,一组用于保存Map里的key,一组用于保存Map里的value,key与map可以是任何引用类型数据。Map的key不允许重复。key与value是单向的一一对应关系,即通过key值总能找到唯一确定的value。

1 Map常用方法

  • void clear():清除Map集合里的所有元素
  • boolean containsKey(Object key):查询Map是否包含指定的key,包含则返回true
  • Set entrySet():返回Map中包含key-value对所组成的Set集合,每个集合元素都是Map.Entry对象
  • Object get(Object key):返回指定key所对应的value,如果此Map不包含此key,返回null
  • Set keySet():返回该Map中所有key组成的Set集合
  • Object put(Object key, Object value):添加一个key-value对,如果key已经存在,则会覆盖
  • void putAll(Map m):将指定的Map集合复制到本Map
  • Object remove(Object key):删除指定key对应的key-value对
  • int size():返回Map元素的个数
  • Collection values():返回Map里所有value组成的Collection

  

  2 HashMap 与Hashtable

HashMap与Hashtable都是Map接口的实现类,它们之间的关系类似与ArrayList与Vector:Hashtable是一个古老的Map实现类,从JDK1.0就有了,从它的命名就可以看出,甚至没有遵循Java命名规范。

  • Hashtable是线程安全的,HashMap不是,所以HashMap性能要好些
  • Hashtable不允许使用null作为key与value,HashMap可以,但是也只能存储一个null作为key值
  • HashMap是无序的

  

         HashMap<String, String> hash = new HashMap<String, String>();
hash.put("吴国谋士", "周瑜");
hash.put("蜀国军师", "诸葛亮");
hash.put("魏国谋士", "郭嘉"); //foreach遍历
for(Object key:hash.keySet())
{
String name = hash.get(key);
System.out.println(key+"-->"+name);
} //Iterator遍历
Iterator iter = hash.keySet().iterator();
while(iter.hasNext())
{
String key = (String)iter.next();
String name = hash.get(key);
System.out.println(key+"-->"+name);
} //将HashMap转为Set,Set里存储的是Map.Entry<K, V>
Set set = hash.entrySet();
Iterator iter1 = set.iterator(); while(iter1.hasNext())
{
Map.Entry<String, String> item = (Map.Entry<String, String>)iter1.next();
System.out.print(item.getKey()+"-->"+item.getValue()+" ");
}

HashMap中存储、获取对象,其中用作key的对象必须实现hashCode方法与equals方法,类似与HashSet,HashMap判断两个key值相等的标准也是:两个key 通过equals()比较返回true,那么两个key的hashCode值也相等。相对key的判断,value的判断就要简单些,两个value只需要通过equals()比较返回true即可。

关于HashSet,HashMap的equals()与hashCode()重写:http://www.cnblogs.com/Latiny/p/8359088.html

3 LinkedHashMap

LinkedHashMap是HashMap的子类,类似于LinkedHashSet,也是使用双向链表来维护key-value对的次序(其实只需要考虑key的次序),该链表负责维护Map的迭代顺序,迭代顺序与key-value插入顺序一致。LinkedHashMap可以避免对HashMap里的key-value对进行排序,同时又可避免使用TreeMap所增加的成本。由于它需要维护元素的插入顺序,因此性能略低于HashMap,但是因为它以链表来维护内部顺序,所以在迭代访问Map里的全部元素时有较好的性能。

         LinkedHashMap map = new LinkedHashMap();
map.put("Lakers", "KOBE");
map.put("Celtics", "Irving");
map.put("Warries", "KD");
map.put("Cavaliers", "James"); Iterator iter= map.keySet().iterator();
while(iter.hasNext())
{
String key = (String)iter.next();
System.out.println(key+"-->"+map.get(key)); } for(Object key:map.keySet())
{
System.out.println(key+"-->"+map.get(key));
}

  输出结果:

Lakers-->KOBE
Celtics-->Irving
Warries-->KD
Cavaliers-->James

可以看到LinkedHashMap遍历的顺序是插入时的顺序,与HashMap截然不同,HashMap遍历的结果是无序的。

  

  4 TreeMap

TreeMap与TreeSet类似,也是一个红黑树结构。每个key-value对作为红黑树的一个节点。TreeMap存储key-value对时,需要根据key对节点进行排序。TreeMap可以保证所有key-value对处于有序状态。TreeMap额外提供了一系列根据key值访问key-value的方法

Map.Entry() firstEntry():返回该Map中最小key所对应的key-value对,如果该Map为空,则返回null

Map.Entry() lastEntry():返回该Map中最大key所对应的key-value对,如果该Map为空,则返回null

Object firstKey():返回该Map中最小的key值

Object lastKey():返回该Map中最大的key值

Java Map 集合实现类的更多相关文章

  1. Java | Map集合

    Map集合 在现实生活中,有非常多的东西,是和另外一种东西对应的,并且还是唯一的,比如:身份证号与个人,个人与手机,一夫一妻...等,这种关系就是对应关系,又叫做映射.Java为这种数据类型提供了专门 ...

  2. java Map集合对比分析

    1.Map:Map是所有map集合的顶级父接口,用于key/value形式的键值对,其中每一个key都映射到一个值,key不能重复. 2.TreeMap:该map将存储的键值对进行默认排序,并且还能够 ...

  3. java之集合工具类Collections

    Collections类简介 java.utils.Collections 是集合工具类,用来对集合进行操作.此类完全由在 collection 上进行操作或返回 collection 的静态方法组成 ...

  4. Java Map集合 遍历 五种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.HashMap; import java.util.Iterator; import ...

  5. java map集合的知识

    /** * Map用于存储键值对,不允许键重复,值可以重复. * (1)HashMap是一个最常用的Map,它根据键的hashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度. * H ...

  6. Java Map集合按照key和value排序之法

    一.理论基点 Map是键值对的集合接口,它的实现类主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等. TreeMap:基于红黑树(Red-Black-Tre ...

  7. java的集合工具类Collections

    集合框架的工具类. Collections:集合框架的工具类.里面定义的都是静态方法. Collections和Collection有什么区别? Collection是集合框架中的一个顶层接口,它里面 ...

  8. Java学习笔记之:Java Map集合

    一.介绍 通常来说,Map是一个由键值对组成的数据结构,且在集合中每个键是唯一的. 二.笔记 /** * Map:接口. 不是collection的子类 key -value 键值对 key唯一不能重 ...

  9. Java map的匿名类的初始化

    可以直接使用: Map<String, Object> testMap = new HashMap<String, Object>() { { put("test1& ...

随机推荐

  1. [福大软工] Z班 第4次成绩排行榜

    作业要求 http://www.cnblogs.com/easteast/p/7511234.html 评分细则 (1)博客--15分,分数组成如下: 随笔开头,给出结队两个同学的学号.PS:结对成员 ...

  2. Flex读取txt文件里的内容(一)

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/you23hai45/article/details/25248307  Flex读取txt文件里的内 ...

  3. PHP小接

    一种是innodb,一种是myisam,两者的主要区别是①myisam不支持事务处理,而innoDB支持事务处理 ②myisam 不支持外键,innoDB支持外键 ③myisam支持全文检索,而inn ...

  4. 构建企业 YUM仓库

    构建企业 YUM仓库 本地光盘提供基础软件包Base yum缓存提供update软件包 yum缓存提供常用软件包: nginx, zabbix, docker, saltstack 环境准备 系统 I ...

  5. 【vue】vue +element 搭建项目,Qs用途

    1.安装 (c)npm install qs -S 2.用途 在 axios中,利用QS包装data数据 3.常见用法: import Qs from 'qs'; Qs.stringify(data) ...

  6. 英文字母对应的Unicode编码

    A~Z :65~90 a~z :97~122 0-9 : 48-57 如果想要知道字符串中的值是否是小写英文字符,不使用工具包的一种方法就是使用Unicode编码值,举例: package main ...

  7. javaScript的原型模式

    一.原型模式: 这个只存在于函数中. 我们在创建的每一个函数中都有一个prototype(原型)属性,这个属性是一个指针,指向一个对象,而这个对象的用途是包含可以有特定类型 的所有实例共享的属性和方法 ...

  8. object detection[YOLO]

    这部分,我们来聊聊YOLO. YOLO:You Only Look Once,顾名思义,就是希望网络在训练过程中,一张图片只要看一次就行,不需要去多次观察,比如滑框啥的,从而从底层原理上就减少了很多的 ...

  9. linux驱动之中断处理过程汇编部分

    linux系统下驱动中,中断异常的处理过程,与裸机开发中断处理过程非常类似.通过简单的回顾裸机开发中断处理部分,来参考学习linux系统下中断处理流程. 一.ARM裸机开发中断处理过程 以S3C244 ...

  10. 容器技术|Docker三剑客之docker-compose

    三剑客简介 docker-machine docker技术是基于Linux内核的cgroup技术实现的,那么问题来了,在非Linux平台上是否就不能使用docker技术了呢?答案是可以的,不过显然需要 ...