Map

1、Map实现类:HashMap、Hashtable、LinkedHashMap、TreeMap

  • HashMap 

    • 新增元素/获取元素

       1     void contextLoads() {
      2 //声明
      3 Map<String,Object> hashMapOne=new HashMap<>();
      4
      5 // .put 添加元素,添加重复的key,不会添加成功,但是会更新key对应的value值
      6 hashMapOne.put("name","zhangsan");
      7 hashMapOne.put("name","lisi");
      8 System.out.println(hashMapOne.get("name")); //输出结果是 lisi(替换了原来的zhangsan)
      9
      10 // .putIfAbsent key存在时,不覆盖原来key的value值,也不新增这个重复的key
      11 hashMapOne.put("age","3");
      12 hashMapOne.putIfAbsent("age","10");
      13 System.out.println(hashMapOne.get("age")); //输出结果是3,没有被替换
      14
      15 // .putall 复制,将所有元素从一个HashMap复制到另一个HashMap
      16 Map<String,Object> hashMapTwo=new HashMap<>();
      17 hashMapTwo.put("age","5");
      18 hashMapTwo.put("sex","女");
      19 hashMapTwo.putAll(hashMapOne);
      20 //hashMapOne中的age覆盖了hashMapTwo原来的age,输出3
      21 System.out.println(hashMapTwo.get("age"));
      22 //hashMapOne中没有sex,所以输出hashMapTwo原来的sex,女
      23 System.out.println(hashMapTwo.get("sex"));
      24 //hashMapOne中的name,复制到了hashMapTwo中,输出lisi
      25 System.out.println(hashMapTwo.get("name"));
      26
      27 // .get获取元素上面的输出语句有
      28 // .getOrDefault 当key不存在时,设置一个默认值,输出"上海"
      29 System.out.println(hashMapOne.getOrDefault("area","上海"));
    • 遍历元素
           void contextLoads() {
      //声明
      Map<String,Object> hashMapOne=new HashMap<>();
      hashMapOne.put("name","zhangsan");
      hashMapOne.put("age","25");
      hashMapOne.put("area","上海"); //1、使用keySet获取所有的Key,然后遍历
      System.out.println("方式1:使用keySet遍历");
      for (String key : hashMapOne.keySet()){
      System.out.println(key + " " + hashMapOne.get(key));
      } //2、使用Map.entrySet获取所有的元素,然后使用iterator遍历
      System.out.println();
      System.out.println("方式2:通过Map.entrySet使用iterator遍历");
      Iterator<Map.Entry<String,Object>> iterator=hashMapOne.entrySet().iterator();
      while (iterator.hasNext()){
      Map.Entry<String, Object> entry = iterator.next();
      System.out.println("Key:" + entry.getKey() + ",Value:" + entry.getValue());
      } //3、用Map.entrySet获取所有的元素,然后使用foreach循环遍历
      System.out.println();
      System.out.println("方式3:通过Map.entrySet使用foreach循环遍历");
      for (Map.Entry<String, Object> entry : hashMapOne.entrySet()) {
      System.out.println("Key:" + entry.getKey() + ",Value:" + entry.getValue());
      } //4、直接使用values获取到所有的值,该种方式无法遍历Key
      System.out.println();
      System.out.println("方式4:使用values遍历,使用这种方式无法遍历Key");
      for (Object value : hashMapOne.values()) {
      System.out.println(value);
      }
      }
  • HashMap、Hashtable、LinkedHashMap、TreeMap 的区别
  相同点:
    • 都实现了Map接口
    • 都不允许key重复
  不同点
不同点 HashMap Hashtable LinkedHashMap TreeMap
排序 不排序 不排序 按插入顺序排序
有默认排序
【按照key的字典顺序升序排序】
可自定义排序
null值
Key:允许
Value:允许
Key:不允许
Value:不允许
Key:允许
Value:允许
Key:不允许
Value:允许
线程安全 非线程安全 线程安全 非线程安全 非线程安全
继承的父类 AbstractMap Dictionary HashMap>AbstractMap AbstractMap

Java - 集合 - Map的更多相关文章

  1. Java集合Map接口与Map.Entry学习

    Java集合Map接口与Map.Entry学习 Map接口不是Collection接口的继承.Map接口用于维护键/值对(key/value pairs).该接口描述了从不重复的键到值的映射. (1) ...

  2. Java集合——Map接口

    1.定义 Map用于保存存在映射关系<key,value>的数据.其中,key值不能重复(使用equals()方法比较),value值可以重复 2.方法 V  put(key,value) ...

  3. Java集合—Map

    简介 Map用户保存具有映射关系的数据,因此Map集合里保存着两组数,一组值用户保存Map里的key,另一组值用户保存Map里的value,key和value都可以是任何引用类型的数据.Map的key ...

  4. Java集合Map基本方法

    jdk1.7 api中的方法摘要: 参考java集合大全图:https://www.cnblogs.com/xkzhangsanx/p/10889114.html Map为所有Map子类的接口.

  5. java集合——Map

    声明:以下内容都是来自网络总结,将会参考很多,没有声明转载来源. 一.Map接口 1.HashMap HashMap和HashTable的区别:http://blog.csdn.net/shohoku ...

  6. Java集合--Map总结

    转载请注明出处:http://www.cnblogs.com/skywang12345/admin/EditPosts.aspx?postid=3311126 第1部分 Map概括 (01) Map ...

  7. Java集合-----Map详解

          Map与Collection并列存在.用于保存具有映射关系的数据:Key-Value      Map 中的 key 和  value 都可以是任何引用类型的数据      Map 中的 ...

  8. Java集合Map与其子类回顾

    接10月12号昨天的笔记,今天继续回顾集合中的Map集合. 一.集合工具操作类Collections 问题:collection和collections的区别? 1.collection是单列集合的顶 ...

  9. Java集合----Map集合

    Map Map 用于保存具有映射关系的数据,因此 Map 集合里保存着两组值,一组值用于保存 Map 里的 Key,另外一组用于保存 Map 里的 Value Map 中的 key 和 value 都 ...

  10. Java 集合-Map接口和三个子类实现

    2017-10-31 22:05:59 Map 将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. HashMap是基于散列表实现的,插入.删除和定位元素时间复杂度平均能达到O ...

随机推荐

  1. docker镜像ubuntu封装jdk1.8.0【dockerfile】

    github地址:https://github.com/laileman/Docker/Dockerfile/ubuntu-jdk1.8.0_172 1-目录结构 2- dockerfile内容 3- ...

  2. Java参数传递是值传递还是引用传递?

    当一个对象被当作参数传递到一个方法后,在此方法内可以改变这个对象的属性,那么这里到底是值传递还是引用传递? 答:是值传递.Java 语言的参数传递只有值传递.当一个实例对象作为参数被传递到方法中时,参 ...

  3. php 获取header信息

    nginx服务器获取header信息: 如:获取token: $_SERVER['HTTP_TOKEN']; 获取自定义的参数采用$_SERVER['参数名'] Apache服务器获取header信息 ...

  4. phpstorm格式化数组

    如果我们想要的这样的数组格式的话,可以设置 <?php $arr = array["a" => 0, "b" => 1, "c&qu ...

  5. (转)linux 之 grep命令

    转自:http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2856896.html 简介 grep (global search regular e ...

  6. 条件锁Condition

    """设计场景:timo先说一句,亚索再说一句timo: timo队长正在待命yasuo: 面对疾风吧timo: timo整装待发yasuo: 哈杀gay "& ...

  7. python面试的100题(12)

    25.求出列表所有奇数并构造新列表 a=[1,2,3,4,5,6,7,8,9,10] res=[i for i in a if i%2==1] print(res) 结果为:[1, 3, 5, 7, ...

  8. 算法竞赛入门经典第二版 竖式问题 P42

    #include<bits/stdc++.h> using namespace std; int inset(char *s,int num) { //判断数字是否在数字集中 int le ...

  9. 读书笔记 (.NET企业级应用架构设计)

    建议你自己和别人多沟通(学会沟通会使你在公司更好的发展,有意见就提,有问题就问,有困难就说)加油lxp 1.架构师是用来干嘛的: 架构师分析需求,分析系统要去做什么,架构怎么去做 2.架构师的职责是: ...

  10. 【C语言】思维导图

    长按图片或右键另存为保存哦(´-ω-`)