Java HashMap浅析

一、什么是HashMap

HashMap是一个通过键值对存储数据的容器,所谓容器就是能够自动扩容的存储工具。我之前一直很好奇为什么叫Map,不是地图的意思吗?查了一下字典终于是明白了,这里的Map应该翻译成——映射

二、原理

1.构造

HashMap构造的时候会有默认的初始容量16,以及扩展因子,默认是0.75。数据存储的比例达到扩展因子之后,HashMap就会扩充,增加大小是2倍,和C++的Vector类似。长度小于8的时候是链表,后面就会转为红黑树存储。

2.modCount

大概就是HashMap的结构信息,每次增加或者删除数据都会维护这个值。

3.fail-fast机制

在我们常见的java集合中就可能出现fail-fast机制,比如ArrayList,HashMap。在多线程和单线程环境下都有可能出现快速失败。

单线程在迭代的时候remove一个元素就会有fail-fast。

多线程更常见。

可以通过并发包java.util.concurrent的类代替HashMap,这样在并发过程中不会出现fail-fast问题。

4.hashcode

Java的每个对象都有hashcode方法,hashMap遇到冲突是使用的拉链法。

三、具体使用

Map<String,String> a = new HashMap<>();
        a.put("a","1");
        String data = a.get("a");
        System.out.println("data"+data);
        System.out.println(a.hashCode());
        a.remove("a");
        System.out.println(a.hashCode());

输出结果 1 ,80,0

80就是哈希值了。

最后哈希表为空的时候,哈希值也为0。

四、tips

  • 在HashMap中通过get()来获取value,通过put()来插入value,ContainsKey()则用来检验对象是否已经存在。可以看出,和ArrayList的操作相比,HashMap除了通过key索引其内容之外,别的方面差异并不大。

  • 不必对每个不同的对象都产生一个唯一的hashcode,只要你的HashCode方法使get()能够得到put()放进去的内容就可以了。即"不为一原则"。 生成hashcode的算法尽量使hashcode的值分散一些,不要很多hashcode都集中在一个范围内,这样有利于提高HashMap的性能。即"分散原则"。

暂时先写这么多吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值