HashMap源码解析(jdk1.8)
HashMap在开发中经常用,而且面试的时候肯定也会被问到,所以了解源码是很有必要的,能够让我们更好的使用HashMap,今天总结一下,在最后面会有相关面试题。本文不会对红黑树代码由太多深入研究,特别是删除方面太复杂,我们知道红黑树的特点和基本实现原理差不多就可以了,这里推荐先学习2-3树,然后学习红黑树就会水到渠成,然后能够手写实现红黑树就挺好的。 这里HashMap源码基于jdk1.8,我们都知道1.8版本的HashMap有很大改变,而且现在开发一般也都是使用jdk1.8+版本,HashMap底层通过数组+链表+红黑树实现,对红黑树和链表不了解可以参考: Java数据结构和算法(四)–链表 Java数据结构和算法(八)–红黑树与2-3树 HashMap数据结构: 基本结构: public class HashMap < K , V > extends AbstractMap < K , V > implements Map < K , V > , Cloneable , Serializable { private static final long serialVersionUID = 362498820763181265 L ; } 继承了AbstractMap,又实现了Map,这里算是jdk集合开发者的一个失误吧,后来证明这样写应该是没什么用的,只是一直保留下来了