吉法师的博客

不知道能否追到喜欢的人呀,今年努力下吧~ 2022.1.4

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的性能。即"分散原则"。

暂时先写这么多吧。


Share