前言:第一次写学习贴,看了很多的帖子,然后也去看了hashMap的源码,想尝试自己去写一下自己对于这个东西的理解,并不一定是对的,可能也就是写出来让自己加深一下基础印象,如果有些的不好的地方请指出。
此博客应该是以JDK1.7为基础的,但是我是以1.8来说的不要混淆了(只因为我懒得打开1.8的源码)
1.HashMap是什么:让我们重新认识一下这个小哥儿
HashMap是java中AbstractMap的子类,是键值对集合java.util.Map的实现类,是作为Map家族中被使用频率最高的小哥哥
HashMap是java面试时基础中被询问频率极高的你不得不懂得面试题1.2.3
2.HashMap基础了解:HashMap家中拥有着好几个兄弟姐妹,但是咱们只是来了解它的,就不多介绍了,先说的感觉最基础的
HashMap是一个无序的键值对集合,是以Key-Value的形式存储数据的,它只允许一个Key为null值,允许多个value为null值
HashMap是一个非线程安全的键值对集合,即当你使用多线程去操作它时,他可能会出现数据不一致,但是如果你需要它达到线程安全的条件时他也是可以做到的,可以用 Collections(肯来克辛斯)的synchronizedMap(神奎耐日德Map)方法使HashMap具有线程安全的能力,或是选择使用ConcurrentHashMap(肯卡韧特HashMap)这样一个线程安全的Map集合达到目的。
最开始HashMap底层是由数组加链表来实