HashMap的常用方法和储存方式

HashMap的常用方法和储存方式


HashMap实现了Map接口。
保存的值是散列的,按照key的hash排列.
数据保存的是Key-Value键值对.Key不允许重复.
若key保存的自定义对象,则该对象的类必须重写hashCode和equals方法
HashMap非线程安全。


所有实现Map接口的类,key不允许重复,如果新增元素key重复,则新元素覆盖旧元素

常用操作

        HashMap<Integer, String> testHashMap = new HashMap<>();
        testHashMap.put(1, "覆盖前");
        testHashMap.put(1,"覆盖后");
        testHashMap.put(2, "Two");
        testHashMap.put(3, "Three");
        System.out.println(testHashMap.remove(1));//删除元素并返回元素
        System.out.println(testHashMap.replace(2, "2"));//修改元素并返回修改前的元素
        System.out.println(testHashMap.get(3));         //通过键查询值
        //通过键查值如果键不存在,返回默认值
        System.out.println(testHashMap.getOrDefault(4, "这是默认值"));
        System.out.println(testHashMap);

结果

覆盖后
Two
Three
这是默认值
{2=2, 3=Three}

Process finished with exit code 0


遍历值value

        Collection<String> values = testHashMap.values();
        for (String s:values) {
            System.out.println(s);
        }

遍历key和value

方法1

        testHashMap.forEach((key,value)->{
            System.out.println(key+":"+value);
        });

方法2

        testHashMap.entrySet().forEach(o->{
            System.out.println(o.getKey()+":"+o.getValue());
        });

方法3

        Iterator<Integer> iterator = testHashMap.keySet().iterator();
        while (iterator.hasNext()){
            Integer next = iterator.next();
            System.out.println(next+":"+testHashMap.get(next));
        }


HashMap的储存方式

HashMap采用的是数组+链表的储存方式
元素的key的hash值 除以 集合的长度 的余数。
余数为该元素所在数组的下标,如果计算出现两个下标一样的,则使用单链表指向后一个元素,后一个元素不在该数组内。
所以当HashMap的key为引用类型时,必须确保它的所在类重写了hashCode和equals方法,否则插入元素时一定会出现异常。

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值