一、Map接口

Map集合的特点是:通过key值找到对应的value值,key值是唯一的,value可以重复。Map中的元素是无序的,但是也有实现了排序的Map实现类,如:TreeMap。

上面Map接口提供的方法大致可以分为下面几种:

1、put/putAll/remove/clear  增加删除     get/values 获取值

2、containKey/containValue 判断

3、entrySet/keySet 获取迭代

4、equals/hashcode 比较

基本上所有的 Map 接口实现类都使用 put() 方法存入数据、用get() 方法去除数据,使用 entrySet/keySet 迭代获取 Map 数据。

  1. package com.chanshuyi.collection.map;
  2.  
  3. import java.util.Collection;
  4. import java.util.HashMap;
  5. import java.util.Iterator;
  6. import java.util.Map;
  7. import java.util.Map.Entry;
  8. import java.util.Set;
  9.  
  10. public class HashMapTest {
  11.  
  12. public static void main(String[] args) {
  13. //增加
  14. Map<String, String> map = new HashMap<String, String>();
  15. map.put("1", "Tom");
  16. map.put("2", "Marry");
  17. map.put("3", "Jacket");
  18. map.put("1", "TomCopy"); //会覆盖掉原来的key为1的Tom
  19.  
  20. System.out.println("Map长度:" + map.size());
  21.  
  22. //删除
  23. map.remove("1");
  24.  
  25. //查询
  26. System.out.println("key为3的值:" + map.get("3"));
  27. }
  28. }

所有的 Map 实现类都可以有四种方式实现Map数据的迭代:

  1. package com.chanshuyi.collection.map;
  2.  
  3. import java.util.Collection;
  4. import java.util.HashMap;
  5. import java.util.Iterator;
  6. import java.util.Map;
  7. import java.util.Map.Entry;
  8. import java.util.Set;
  9.  
  10. public class HashMapTest {
  11.  
  12. public static void main(String[] args) {
  13. Map<String, String> map = new HashMap<String, String>();
  14. map.put("1", "Tom");
  15. map.put("2", "Marry");
  16. map.put("3", "Jacket");
  17. map.put("1", "TomCopy"); //会覆盖掉原来的key为1的Tom
  18.  
  19. //迭代1 keySet()
  20. for(String key : map.keySet()){
  21. System.out.print(map.get(key) + " ");
  22. }
  23. System.out.println();
  24.  
  25. //迭代2 entrySet()
  26. Set<Entry<String, String>> entrySet = map.entrySet();
  27. for(Entry<String, String> entry : entrySet){
  28. System.out.print(entry.getKey() + ":" + entry.getValue() + " ");
  29. }
  30. System.out.println();
  31.  
  32. //迭代3 entrySet()
  33. Iterator<Entry<String, String>> it = map.entrySet().iterator();
  34. while(it.hasNext()){
  35. Entry<String, String> entry = it.next();
  36. System.out.print(entry.getKey() + ":" + entry.getValue() + " ");
  37. }
  38. System.out.println();
  39.  
  40. //迭代4 map.values()
  41. Collection<String> col = map.values();
  42. for(String str : col){
  43. System.out.print(str + " ");
  44. }
  45. }
  46. }

二、HashMap实现类

HashMap 的内部结构是一个数组和链表的结构,存取数据时通过 key 计算哈希值,并将哈希值对Map大小取模确定存取位置。

如果该位置上已经有数据了,那么就通过链表的形式存在该链表上,如果没有则直接存在这个位置上。需要注意的是 HashMap 是非线程同步的,因此在多线程环境下不能使用 HashMap,否则会出现数据错误。

在使用上,HashMap 的使用和 Map 接口没什么区别,也是用 put()/get() 存取数据,用keySet()/entrySet() 迭代 Map,例子可以参考上面 Map 接口的例子,这里不再赘述。

三、Hashtable 实现类

Hashtable实现类同样实现了Map接口,其内部实现以及结构完全与HashMap相同,唯一的区别就是:Hashtable是线程同步的,而HashMap是非线程同步的。因此在多线程环境中推荐用Hashtable,而在非线程环境中用HashMap。

与HashMap一样,Hashtable也是用Map接口提供的 put/get/keySet/entrySet 进行数据操作。例子可以参考上面Map接口的例子,这里不再赘述。

四、WeakHashMap实现类

WeakHashMap 是指弱引用的 HashMap类。弱引用是 Java 引用强度中的一种,弱引用类型告诉 JVM:在你产生内存不足的时候,你可以把 WeakHashMap 类对象的空间释放。也就是说:当除了自身有对 key 有引用外,没有其他变量引用 WeakHashMap 对象,那么此 WeakHashMap 对象会自动丢弃此key对应的value值。

见实例:三个匿名字符串,WeakHashMap 只保留了它们的弱引用,而第4个是字符串直接量,系统会保留该对象的强引用。

  1. package com.chanshuyi.collection.map;
  2.  
  3. import java.util.WeakHashMap;
  4.  
  5. public class WeakHashMapTest1 {
  6. public static void main(String[] args) throws Exception {
  7. WeakHashMap<String, String> whm = new WeakHashMap<String, String>();
  8. //添加三个键值对
  9. //三个key键都是匿名字符串对象(没有其它引用)
  10. whm.put(new String("语文"),new String("良好"));
  11. whm.put(new String("数学"),new String("及格"));
  12. whm.put(new String("英文"),new String("中等"));
  13. //添加一个键值对
  14. //该Key是一个系统缓存的字符串对象
  15. whm.put("java",new String("中等"));
  16. //输出whm,将看到四个键值对
  17. System.out.println("Fitst Time:" + whm);
  18. //通知系统进行垃圾回收
  19. System.gc();
  20. System.runFinalization();
  21. //通常情况下将只看到一个键值对
  22. System.out.println("Second Time:" + whm);
  23. }
  24. }

输出结果是:

  1. Fitst Time:{英文=中等, java=中等, 数学=及格, 语文=良好}
  2. Second Time:{java=中等}

五、TreeMap实现类

TreeMap类实现了SortedMap 接口,实现了 Map 集合的排序。TreeMap中实现元素排序与TreeSet的实现方式一样,有两种方式:

1、JavaBean中实现Comparable接口的compareTo()方法

  1. package com.chanshuyi.collection.map;
  2.  
  3. import java.util.TreeMap;
  4.  
  5. public class TreeMapTest1 {
  6. public static void main(String[] args) {
  7. TreeMap<String, Student> treeMap = new TreeMap<String, Student>();
  8. treeMap.put("Zpple", new Student("Tpple", 10)); //Map数据是根据key进行排序的
  9. treeMap.put("Tpple", new Student("Tpple", 12));
  10.  
  11. for(String key : treeMap.keySet()){
  12. System.out.print(treeMap.get(key) + " ");
  13. }
  14. }
  15. }
  16.  
  17. class Student implements Comparable<Student>{
  18. private String name;
  19.  
  20. private int age;
  21.  
  22. public Student(String name, int age) {
  23. super();
  24. this.name = name;
  25. this.age = age;
  26. }
  27.  
  28. public String getName() {
  29. return name;
  30. }
  31.  
  32. public void setName(String name) {
  33. this.name = name;
  34. }
  35.  
  36. public int getAge() {
  37. return age;
  38. }
  39.  
  40. public void setAge(int age) {
  41. this.age = age;
  42. }
  43.  
  44. @Override
  45. public int compareTo(Student s) {
  46. if(this.age > s.getAge()){
  47. return 1; //按照自然排序
  48. }else if(this.age == s.getAge()){
  49. return 0;
  50. }else{
  51. return -1;
  52. }
  53. }
  54.  
  55. public String toString(){
  56. return "[" + this.name + "," + this.age + "]";
  57. }
  58. }

2、构建自定义比较器(实现Comparator接口)

  1. package com.chanshuyi.collection.map;
  2.  
  3. import java.util.Comparator;
  4. import java.util.TreeMap;
  5.  
  6. public class TreeMapTest2 {
  7.  
  8. public static void main(String[] args) {
  9. TreeMap<String, Student> treeMap = new TreeMap<String, Student>(new MyComparator());
  10. treeMap.put("Apple", new Student("Zpple", 10)); //Map数据是根据key进行排序的
  11. treeMap.put("Tpple", new Student("Tpple", 12));
  12.  
  13. for(String key : treeMap.keySet()){
  14. System.out.print(treeMap.get(key) + " ");
  15. }
  16. }
  17. }
  18.  
  19. class MyComparator implements Comparator<String>{ //用Map的key进行比较
  20. @Override
  21. public int compare(String o1, String o2) {
  22. return o1.compareTo(o2);
  23. }
  24. }

4.Java集合总结系列:Map接口及其实现的更多相关文章

  1. Java集合框架之Map接口浅析

    Java集合框架之Map接口浅析 一.Map接口综述: 1.1java.util.Map<k, v>简介 位于java.util包下的Map接口,是Java集合框架的重要成员,它是和Col ...

  2. Java集合框架中Map接口的使用

    在我们常用的Java集合框架接口中,除了前面说过的Collection接口以及他的根接口List接口和Set接口的使用,Map接口也是一个经常使用的接口,和Collection接口不同,Map接口并不 ...

  3. Java集合中的Map接口

    jdk1.8.0_144 Map是Java三种集合中的一种位于java.util包中,Map作为一个接口存在定义了这种数据结构的一些基础操作,它的最终实现类有很多:HashMap.TreeMap.So ...

  4. Java集合中的Map接口怎么使用?

    Map(双列集合框架) 1.Map接口及实现类概述 Map 接口提供三种collection 视图,允许以键集.值集或键-值映射关系集的形式查看某个映射的内容.映射顺序 定义为迭代器在映射的 coll ...

  5. Java中的集合(十三) 实现Map接口的Hashtable

    Java中的集合(十三) 实现Map接口的Hashtable 一.Hashtable简介 和HashMap一样,Hashtable采用“拉链法”实现一个哈希表,它存储的内容是键值对(key-value ...

  6. Java中的集合(十一) 实现Map接口的TreeMap

    Java中的集合(十一) 实现Map接口的TreeMap 一.TreeMap简介(基于JDK1.8) TreeMap是基于红黑树数据结构,是一个key-value的有序集合,该映射根据其键的自然顺序进 ...

  7. 转:深入Java集合学习系列:HashSet的实现原理

    0.参考文献 深入Java集合学习系列:HashSet的实现原理 1.HashSet概述: HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)支持.它不保证set 的迭代顺序:特 ...

  8. 第19章 集合框架(3)-Map接口

    第19章 集合框架(3)-Map接口 1.Map接口概述 Map是一种映射关系,那么什么是映射关系呢? 映射的数学解释 设A,B是两个非空集合,如果存在一个法则,使得对A中的每一个元素a,按法则f,在 ...

  9. Java集合框架之Collection接口

    Java是一门面向对象的语言,那么我们写程序的时候最经常操作的便是对象了,为此,Java提供了一些专门用来处理对象的类库,这些类库的集合我们称之为集合框架.Java集合工具包位于Java.util包下 ...

  10. Java集合框架之四大接口、常用实现类

    Java集合框架 <Java集合框架的四大接口> Collection:存储无序的.不唯一的数据:其下有List和Set两大接口. List:存储有序的.不唯一的数据: Set:存储无序的 ...

随机推荐

  1. 从C#到TypeScript - async await

    总目录 从C#到TypeScript - 类型 从C#到TypeScript - 高级类型 从C#到TypeScript - 变量 从C#到TypeScript - 接口 从C#到TypeScript ...

  2. Linux学习笔记(1)

    一.介绍 Linux系统作为服务器操作器的两大优点是其稳定性以及安全性:常见的Linux系统有以下几种: Debian(1993年下半年出的Linux分支) Ubuntu(目前互联网公司使用的比较多的 ...

  3. P177 test 6-4 UVa439

    //P177 test 6-4 UVa439 #include<cstdio> #include<cstring> #include<queue> using na ...

  4. 【开源】NodeJS仿WebApi路由

    用过WebApi或Asp.net MVC的都知道微软的路由设计得非常好,十分方便,也十分灵活.虽然个人看来是有的太灵活了,team内的不同开发很容易使用不同的路由方式而显得有点混乱. 不过这不是重点, ...

  5. 应用控制台应用程序开发批量导入EXEL程序。

    一.最近一直在调整去年以及维护去年开发的项目,好久没有在进行个人的博客了.每天抽了一定的时间在研究一些开源的框架,Drapper 以及NHibernate以及当前比较流行的SqlSuper框架 并进行 ...

  6. ReactiveSwift框架

    最近项目不多,所以就研究了一下RxSwift和RAS,RAC以前项目中用过了,在这里我就先简单的介绍一下什么是RAS.总述:在RAC 5.0这个版本,有了很大的改动,API已经重新命名.在和Swift ...

  7. hudson入门

    持续集成hudson入门博客分类: Java 单元测试配置管理maven项目管理Tomcat         极限编程中一项建议实践便是持续集成,持续集成是指在开发阶段,对项目进行持续性自动化编译.测 ...

  8. Html<img>标签特写 2017-03-10 AM

    1.插入图片 <img src="picture1.gif" width="300" height="100" title=" ...

  9. MySQL优化四(优化表结构)

    body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-top: 10 ...

  10. 浅谈Java的集合框架

    浅谈Java的集合框架 一.    初识集合 重所周知,Java有四大集合框架群,Set.List.Queue和Map.四种集合的关注点不同,Set 关注事物的唯一性,List 关注事物的索引列表,Q ...