你对Collection中Set、List、Map理解?

42 阅读1分钟

image.png @[TOC]

一、图

在这里插入图片描述

二、hashMap

1.扩容算法

所以说,当数组长度为2的n次幂的时候,不同的key算得得index相同的几率较小,那么数据在数组上分布就比较均匀,也就是说碰撞的几率小,相对的,查询的时候就不用遍历某个位置上的链表,这样查询效率也就较高了。

hashmap数组扩容之后,最消耗性能的点就出现了:原数组中的数据必须重新计算其在新数组中的位置,并放进去,这就是resize。

2.ConcurrentHashMap原理

底层采用:CAS + synchronized 来保证并发安全性。

3.TreeMap红黑树特性?使用好处?

在这里插入图片描述 使用好处: 1)是一种自平衡二叉树 2)最大长度-最小长度 < 1倍 3)它虽然是复杂的,但它的最坏情况运行时间也是非常良好的,并且在实践中是高效的。

4.LinkedHashMap的特点?数据结构?

在这里插入图片描述 在这里插入图片描述 在这里插入图片描述

三、HashMap底层实现原理及面试问题

blog.csdn.net/suifeng629/…

image.png

重要信息

image.png

image.png

image.png

image.png