zoukankan      html  css  js  c++  java
  • Java学习笔记——浅谈数据结构与Java集合框架(第三篇、Map)

    桃李春风一杯酒,江湖夜雨十年灯

                  ——寄黄几复

    之前图上写错了,是Hashtable类。t是小写的,它是个很古老的类,以至于命名都没有那么规范..

    HashMap

    HashMap就是存储key-value键值对的集合,是一种映射关系。key中的元素组成了一个Set集合(key无序,不允许重复,可以是null),且任意key中的元素有且只有一个value值与其对应(value值可以是null)

    上代码:

     1 public class MapTest {
     2 
     3     public static void main(String[] args) {
     4         Map<String, Integer> map = new HashMap<>();
     5         //成对放入
     6         map.put("疯狂Java讲义", 109);
     7         map.put("疯狂iOS讲义", 10);
     8         map.put("疯狂Ajax讲义", 79);
     9         //value可以重复
    10         map.put("轻量级Java EE企业应用实战", 79);
    11         //key重复时,新的value会覆盖原有的value,并返回被覆盖的value值,输出:10,不重复返回null
    12         System.out.println(map.put("疯狂iOS讲义", 108));
    13         //无序的,形式{key =value,key=value,...}
    14         System.out.println(map);
    15         //是否包含指定key,输出:true
    16         System.out.println(map.containsKey("疯狂Java讲义"));
    17         //是否包含指定value,输出:true
    18         System.out.println(map.containsValue(79));
    19         //获取所有key集合,通过key,value遍历所有
    20         for (String item : map.keySet()) {
    21             System.out.println(item+"--"+map.get(item));
    22         }
    23         //entry遍历
    24         for (Entry<String, Integer> item : map.entrySet()) {
    25             System.out.println(item.getKey()+"--"+item.getValue());
    26         }
    27         map.remove("疯狂Java讲义");
    28         System.out.println(map);
    29     }
    30 }

    Java8新增方法:

     1 public class MapTest02 {
     2 
     3     public static void main(String[] args) {
     4         Map<String, Integer> map = new HashMap<>();
     5         //成对放入
     6         map.put("疯狂Java讲义", 109);
     7         map.put("疯狂iOS讲义", 10);
     8         map.put("疯狂Ajax讲义", 79);
     9         //尝试替换value值
    10         map.replace("疯狂Java讲义", 56);
    11         System.out.println(map);
    12         //没有找到key,所以不会替换
    13         map.replace("疯狂Jav讲", 12);
    14         System.out.println(map);
    15         //使用原value与传入参数计算出来的结果覆盖原value
    16         //该方法调用BiFunction<T, U, R>接口的apply(oldValue, value)方法,该接口为函数式接口(只含有一个抽象方法的接口),可使用lambda表达式
    17         map.merge("疯狂Java讲义", 23, (oldVal,newVal) -> oldVal/newVal);//Value值为56/23
    18         //key为Java对应的value为null或者key本身为null时使用计算结果作为新value
    19         map.computeIfAbsent("Java", (key) -> ((String)key).length());
    20         //key为Java对应的value为存在时使用计算结果作为新value
    21         map.computeIfPresent("Java",(key,value) -> value*value );//感觉这个lambda表达式没什么用
    22         System.out.println(map);
    23     }
    24 }

    Hashtable

    Hashtable是一个线程安全的实现,HashMap是线程不安全的。所有HashMap性能比HashTable高一些。但如果多个线程访问同一个Map对象也可以使用Hashtable。

    Hashtable不允许使用null作为key值和value值,如果使用,将会引发NullPointerException

    判断HashMap和HashTable中key值是否重复的方法和判断HashSet中元素是否重复是一样的:

    1、两个key对象equals

    2、连个key对象的hashCode相等

    判断HashMap和HashTable都有containsValue()方法,判断连个value相等的标准是:

    两个对象通过equals方法比较返回true即可

     TreeMap

     类似TreeSet,TreeMap的key值自然排序

  • 相关阅读:
    spring-cloud-gateway动态路由
    spring-cloud-gateway静态路由
    activiti6官方示例笔记
    spring-cloud-gateway过滤器实践
    spring-cloud-gateway简介
    设计模式--策略模式
    学习ConcurrentHashMap1.7分段锁原理
    SpringBoot Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.
    MYSQL触发器的使用
    储存过程 (创建,调用,查询,删除)
  • 原文地址:https://www.cnblogs.com/tomasman/p/6843636.html
Copyright © 2011-2022 走看看