问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

hashmap底层实现原理是什么?

发布网友 发布时间:2022-03-25 21:21

我来回答

2个回答

热心网友 时间:2022-03-25 22:50

HashMap的实现原理:首先有一个每个元素都是链表(可能表述不准确)的数组,当添加一个元素(key-value)时,就首先计算元素key的hash值,以此确定插入数组中的位置,但是可能存在同一hash值的元素已经被放在数组同一位置了。

这时就添加到同一hash值的元素的后面,他们在数组的同一位置,但是形成了链表,同一各链表上的Hash值是相同的,所以说数组存放的是链表。而当链表长度太长时,链表就转换为红黑树,这样大大提高了查找的效率。

当链表数组的容量超过初始容量的0.75时,再散列将链表数组扩大2倍,把原链表数组的搬移到新的数组中。

HashMap 的实例有两个参数影响其性能:

初始容量和加载因子。容量是哈希表中桶的数量,初始容量只是哈希表在创建时的容量。

加载因子是哈希表在其容量自动增加之前可以达到多满的一种尺度。当哈希表中的条目数超出了加载因子与当前容量的乘积时,则要对该哈希表进行 rehash 操作(即重建内部数据结构),从而哈希表将具有大约两倍的桶数。在Java编程语言中,加载因子默认值为0.75,默认哈希表元为101。

热心网友 时间:2022-03-26 00:08

HashMap的实现原理:首先有一个每个元素都是链表(可能表述不准确)的数组,当添加一个元素(key-value)时,就首先计算元素key的hash值,以此确定插入数组中的位置,但是可能存在同一hash值的元素已经被放在数组同一位置了。

这时就添加到同一hash值的元素的后面,他们在数组的同一位置,但是形成了链表,同一各链表上的Hash值是相同的,所以说数组存放的是链表。而当链表长度太长时,链表就转换为红黑树,这样大大提高了查找的效率。

当链表数组的容量超过初始容量的0.75时,再散列将链表数组扩大2倍,把原链表数组的搬移到新的数组中。



扩展资料

HashMap和Hashtable的区别

1、HashMap可以接受为null的键值(key)和值(value),而Hashtable则不行。

2、HashMap是非synchronized,而Hashtable是synchronized。意味着Hashtable是线程安全的,多个线程可以共享一个Hashtable;而如果没有正确的同步的话,多个线程是不能共享HashMap的。

3、由于Hashtable是线程安全的也是synchronized,所以在单线程环境下它比HashMap要慢。如果不需要同步,只需要单一线程,那么使用HashMap性能要好过Hashtable。

5、HashMap不能保证随着时间的推移Map中的元素次序是不变的。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
邹树仁浅谈中国古彩戏法 编制教师5年内辞职付多少违约金 机动车驾驶证吊销后能办农机局驾驶证吗 我前几天去农机监理所去办拖拉机驾驶证(G证)但是工作人员说不给办... 现在农机证在哪可以办理啊,好多地方都办不了啊。 ...长出一撮白发,一元钱币大小,中间零星长有几根黑发,白发光亮 24岁有点少白头黑发里会有几根白头发…请问怎么调理…是不是身体将康... 开车可以看出一个人性格吗 开车有天赋的人是什么性格 知道物流货号,如何查物流 epoll为什么这么快,epoll的实现原理 java中几种Map在什么情况下使用,并简单介绍原因及原理 面试中如何回答HashMap的工作原理 关于算法导论 请问java中HashMap是怎么实现的,还有treeMap的实现原理是红黑树,请解释一下红黑树 说一下treemap的实现原理?红黑树的性质?红黑树遍历方式有哪些 谁懂红黑树的插入和删除原理? oppor11重启键在哪 oppo重启功能在哪里 OPPO手机的重启在哪里? OPPO手机重启功能在哪里打开 windows7的桌面是一个系统文件夹吗 Windows 7系统桌面是由什么组成 win7系统显示桌面的快捷键是什么? windows7桌面由哪几部分组成? 在Windows 7中,将整个计算机显示屏幕看作是( )。 A窗口 B背景 C工作台 D桌面 wmdows 7中桌面是指什么? windows7系统中的桌面是指整个屏幕吗 windows7系统中桌面是指整个屏幕吗 windows7的桌面是指什么窗口 hashmap底层实现原理 二叉排序树的建立的过程中是如何实现平衡 什么是《平衡二叉树》 C++实习生面试,一般会问到关于STL的什么知识点 作为java程序员,怎么看待原理性知识? 工作3年的Java程序员应该掌握哪些技能 面试 linux 文件系统怎样io到底层 几种常见的查找算法之比较 HashMap底层原理是怎么实现的,Java培训哪个达内何中公哪个好一些呢,有学过的嘛? 跟着培训班学java感觉很痛苦,还要不要继续学习 剪映剪辑电视剧音频间隔时间久 苹果8p多久上市的 苹果8p什么时候出来的 iphone8p什么时候出的 iphone 8p什么时候上市 iphone8 plus什么时候上市 苹果8p什么时候上市 苹果8plus什么时候出的128g 苹果8p128g是什么时候上市的 苹果8p最后一批生产日期